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

Was this helpful?

  1. Част 4 – Процеси

Изчакване и прекратяване на дъщерен процес

#include<stdlib.h>
void exit(int status);
  • Извикване на exit() изпълнява някои основни стъпки за изключване и след това инструктира ядрото да прекрати процеса.

  • Параметърът на състоянието (status) се използва за обозначаване на изходното състояние на процеса.

  • Когато процес завърши, ядрото изпраща сигнал SIGCHLD към родителят.

pid_t pid = fork();
if (pid > 0) {
   printPIDs("PARENT");
   wait(&child_status);
}
else if (!pid) {
   printPIDs("CHILD");
   exit(0);
} 
else if (pid == -1) {
   printf("ERROR");
   return EXIT_FAILURE;
}

Преди да прекрати процеса, библиотеката C изпълнява следните стъпки:

  • Извиква всички функции, регистрирани с atexit() или on_exit(), в обратен ред на тяхната регистрация.

  • Изчиства всички стандартни отворени вхдни-изходни потоци.

  • Премахва всички временни файлове, създадени с функцията tmpfile().

Тези стъпки завършват цялата работа, която процесът трябва да направи в потребителското пространство, така че exit() извиква системното повикване _exit(), за да позволи на ядрото да се справи с останалата част от процеса на прекратяване:

#include <unistd.h>
void _exit (int status);

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

Когато процес завърши, ядрото изпраща сигнал SIGCHLD към родителският процес. По подразбиране този сигнал се игнорира и родителят не предприема никакви действия. Процесите могат да изберат да обработват този сигнал, чрез системните извиквания signal() или sigaction().

#include<sys/types.h>
#include<sys/wait.h>
pid_t wait(int status);
int WIFEXITED(status);
int WIFSIGNALED(status);
int WIFSTOPPED(status);
int WIFCONTINUED(status);
int WEXITSTATUS(status);
int WTERMSIG(status);
int WSTOPSIG(status);
int WCOREDUMP(status);
  • wait() връща стойността на идентификатора (pid) на дъшерен процес или -1 при грешка.

  • Ако никакъв дъщерен процес не е прекратен, извикването блокира, докато дъщерен процес приключи.

  • WIFEXITED връща вярно (true), ако процесът завърши нормално.

  • При нормално прекратяване WEXITSTATUS осигурява осем бита, които се предават на _exit.

  • WIFSIGNALED връща вярно (true), ако сигнал е причинил прекратяването на процеса.

  • В случай на прекратяване от сигнал WTERMSIG връща номера на този сигнал.

  • В случай на прекратяване от сигнал, WCOREDUMP връща вярно (true), ако процесът натоварва ядро в отговор на получаването на сигнала.

  • WIFSTOPPED и WIFCONTINUED връщат вярно (true), ако процесът е бил спрян или продължен.

  • Ако WIFSTOPPED е вярно (true), WSTOPSIG предоставя номера на сигнала, който е спрял процеса.

При възникване на грешка има две възможни стойности:

Грешка
Информация

ECHILD

Извикващият процес няма дъщерни процеси.

EINTR

Извикването проключи по-рано поради получен сигнал.

PreviousОтпечатване на идентификаторите на процеситеNextИзпълнение и отпечатване на състоянието

Last updated 3 years ago

Was this helpful?