Linux System Programming
Български
Български
  • Въведение
  • Част 1 - Основи на Линукс
    • Какво е системно програмиране?
    • Работна среда
    • Отдалечен достъп
    • Как да получите помощ в Линукс?
    • Файлова система
    • Трансфер на файлове
    • Процеси в Линукс
    • Потребители и групи
    • Файлови разрешения
    • Управление на потребители и групи
    • Стандартни потоци
    • Пренасочване и тръбопроводи
    • Текстовият редактор Nano
    • Упражнение върху основи на Линукс
  • Част 2 – Програмиране
    • Kомпилиране
    • Компилатор
    • Изходен програмен код
    • Компилирайте в асемблер
    • Компилирайте до обектен файл
    • Компилирайте до изпълнима програма
    • Стартирайте изпълнимата програма
    • Библиотеки
    • Архиватор
    • Създаване на обектните файл
    • Създаване на статична и динамична библиотеки
    • Програма за намиране сумата на числа
    • Дебъгване
    • Упражнение върху тема програмиране
  • Част 3 – Файлова система и файлове
    • Файлове
    • Файлови системи и именовани пространства
    • Работа с файлове
    • Буферирани срещу небуферирани потоци
    • Библиотека за работа с файлове
    • Отваряне и затваряне на файл
    • Четене на съдържанието на файл
    • Четене и отпечатване на файл
    • Четене и писане на файл
    • Запис на изречения във файл
    • Търсене в файлове и откъслечни файлове
    • Направете файл с дупка
    • Заключване на файлове
    • Заключи и пиши там
    • Упражнение върху работа с файлове
  • Част 4 – Процеси
    • Процеси
    • Управление на процесите
    • Методи за работа с процеси
    • Изпълнение на команда
    • Показване на изходния код на файла
    • Стартиране на дъщерен процес
    • Отпечатване на идентификаторите на процесите
    • Изчакване и прекратяване на дъщерен процес
    • Изпълнение и отпечатване на състоянието
    • Зомбита и проста обработка на сигнали
    • Игра на зомбита
    • Упражнение върху процеси
  • Част 5 – Комуникация между процеси
    • Методи за комуникация между процеси
    • Сигнали
    • Най-важните сигнали
    • Управление на сигналите
    • Обработка на сигнал
    • Изчакване на сигнали
    • Разглеждане на сигнали
    • Показване на информация за сигналите
    • Reentrancy
    • Анонимни и наименувани тръби
    • Работа с тръби
    • Използване на анонимни тръби
    • Използване на именовани тръби
    • Упражнение върху комуникация между процеси
  • Част 6 - Синхронизация на комуникацията между процесите
    • Опашка за съобщения
    • Библиотеки за работа със съобщения
    • Определяне на общите данни
    • Сървър за съобщения
    • Клиент за съобщения
    • Споделена памет
    • Библиотеки за работа със споделена памет
    • Определяне на общите данни
    • Сървър за памет
    • Клиент за памет
    • Семафори
    • Библиотеки за работа със семафори
    • Определяне на общите данни
    • Семафор Сървър
    • Семафор Клиент
    • Упражнение за синхронизация на комуникация между процеси
  • Част 7 – Сокети
    • Сокетите в Линукс
    • Работа със сокети в C
    • Използване на Unix сокети
    • Файл сокет сървър
    • Файл сокет клиент
    • Двойка сокети
    • Пример за двойка сокети
    • Мрежови сокети
    • Мрежов сокет сървър
    • Мрежов сокет клиент
    • Упражнение върху сокети
  • Част 8 – Нишки
    • Въведение в нишките
    • Библиотека за работа с нишки
    • Функции за управление на нишки
    • Създаване на нишки
    • Финализиране на нишки
    • Съединяване на нишки
    • Пример за съединяване на нишки
    • Функции за прекратяване на нишки
    • Типове при прекратяване на нишки
    • Пример за прекратяване на нишки
    • Упражнение върху нишки
  • Част 9 - Синхронизация на нишки
    • Изход от нишка
    • Управление на изход от нишка
    • Пример за изход от нишкa
    • Защо е необходима синхронизация?
    • Механизми за синхронизация
    • Мютекси
    • Кога е необходимо заключване?
    • Типична употреба на мютекси
    • Проблеми при състезателни условия
    • Безопасен за нишките код
    • Състояние на мъртва хватка
    • Създаване и унищожаване на мютекси
    • Заключване и отключване на мутекси
    • Пример за синхронизиране посредством използване на мютекс
    • Синхронизиране със семафори
    • Пример за синхронизиране посредством използване на семафор
    • Упражнение за синхронизация на нишки
  • Част 10 – Демони
    • Какво са демоните?
    • Скелет на демон
    • Чат демон
Powered by GitBook
On this page
  • pipe-chat-server.c
  • pipe-chat-client.c
  • pipe-echo-chat.c

Was this helpful?

  1. Част 5 – Комуникация между процеси

Използване на именовани тръби

Представената двойка програми реализира чат базирано клиент/сървър приложение, което демонстрира използването на именовани тръби.

pipe-chat-server.c

Създайте файл на име ./pipe-chat-fifo. Отворете за писане ./pipe-chat-fifo в случай на грешка излезте. Стартирайте цикъл, който работи докато получим "q" от клавиатурата. Прочетете символ (key) и го запишете във файла. Ако key е Enter използвайте flush. Затворете и изтрийте файла.

#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
#include<sys/types.h>
#include<sys/stat.h>

#define FIFO_FILE "./pipe-chat-fifo"

int main(int argc, char ** argv)
{
  mkfifo(FIFO_FILE, 0600);
  FILE* f = fopen(FIFO_FILE, "w");
  if(f == NULL)
  {
    printf("Error open file!\n");
    return EXIT_FAILURE;
  }

  char key;
  do
  {
    key = getchar();
    fputc(key, f);
    if(key == 10) fflush(f);
  }
  while(key != 'q');

  fclose(f);
  unlink(FIFO_FILE);
  return EXIT_SUCCESS;
}

Компилирайте и стартирайте програмaта:

gcc pipe-chat-server.c -o pipe-chat-server
./pipe-chat-server

pipe-chat-client.c

Отворете за четене файл на име ./pipe-chat-fifo. Стартирайте цикъл, който работи докато получим "q" от клавиатурата. Прочетете символ (key). Изведете получения символ в конзолата. Затворете и изтрийте файла.

#include<stdlib.h>
#include<stdio.h>
#include<unistd.h>

#define FIFO_FILE "./pipe-chat-fifo"

int main(int argc, char ** argv)
{
  FILE* f = fopen(FIFO_FILE, "r");
  if(f == NULL)
  {
    printf("Error open file!\n");
    return EXIT_FAILURE;
  }

  char key;
  do
  {
    key = fgetc(f);
    putchar(key);
  }
  while(key != 'q');

  fclose(f);
  unlink(FIFO_FILE);
  return EXIT_SUCCESS;
}

Компилирайте и стартирайте програмaта:

gcc pipe-chat-client.c -o pipe-chat-client
./pipe-chat-client

pipe-echo-chat.c

Представената програма реализира чат базирано приложение което връща ехо и демонстрира използването на именовани тръби.

Създайте файл на име pipe-echo-chat-fifo-file. Създайте дъщерен процес (fork) в случай на грешка излезте от програмата:

  • Родителски процес: Отворете за писане pipe-echo-chat-fifo-file в случай на грешка излезте. Четете от клавиатурата и пращайте полученото във файлa. Затворете файлов дескриптор.

  • Дъщерен процес: Отворете за четене pipe-echo-chat-fifo-file в случай на грешка излезте. Прочетете съобщение от входният файлов дескриптор. Отпечатайте полученото съобщение. Затворете файловия дескриптор.

#include<stdio.h>
#include<string.h>
#include<sys/stat.h>
#include<sys/types.h>
#include<stdlib.h>
#include<unistd.h>
#include<fcntl.h>

#define FIFO_FILE "pipe-echo-chat-fifo-file"

int main(int argc, char ** argv)
{
   mkfifo(FIFO_FILE, 0644);

   int pid = fork();
   if(pid == -1)
   {
      printf("Error fork!\n");
      return EXIT_FAILURE;
   }

   if(pid > 0)
   {
      int fd = open(FIFO_FILE, O_WRONLY);
      if(fd == -1)
      {
         printf("Error open file for writing!\n");
         return EXIT_FAILURE;
      }

      char writeBuffer[80];
      while (1)
      {
             fgets(writeBuffer, 80, stdin);
             write(fd, writeBuffer, strlen(writeBuffer) + 1);
      }
      close(fd);
   }
   else
   {
      int fd = open(FIFO_FILE, O_RDONLY);
      if(fd == -1)
      {
         printf("Error open file for reading!\n");
         return EXIT_FAILURE;
      }

      char readBuffer[80];
      while (1)
      {
         read(fd, readBuffer, sizeof(readBuffer));
         printf("%s\n", readBuffer);

      }
      close(fd);
   }

   unlink(FIFO_FILE);

   return EXIT_SUCCESS;
}

Компилирайте и стартирайте програмата:

gcc pipe-echo-chat.c -o pipe-echo-chat
./pipe-echo-chat
PreviousИзползване на анонимни тръбиNextУпражнение върху комуникация между процеси

Last updated 1 month ago

Was this helpful?