Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Ответы по ОС.doc
Скачиваний:
50
Добавлен:
24.09.2019
Размер:
202.24 Кб
Скачать

26)Потоки стандарта Posix.1c

Поток состоит из следующих элементов:

• идентификатора потока;

• динамического стека;

• набора регистров (счетчик команд, указатель стека);

• сигнальной маски;

• значения приоритета;

• специальной памяти.

Поток выполнения создается функцией pthread_create. Каждому потоку присваивается идентификатор, уникальный среди всех потоков процесса. Вновь созданный поток наследует сигнальную маску процесса, динамический стек, значение приоритета и набор регистров. Динамический стек и регистры (счетчик команд и указатель стека) позволяют потоку выполняться независимо от других потоков. Поток может изменить унаследованную сигнальную маску и выделить динамическую память для хранения своих данных.

Потоку при создании назначается соответствующая функция. Поток завершается, когда эта назначенная функция возвращает результат или когда поток вызывает функцию pthread_exit. Когда в процессе создается первый поток, то фактически создаются два потока: один - для выполнения указанной функции, а другой - для продолжения выполнения процесса. Последний поток завершается, когда функция main возвращает результат или он сам вызывает функцию pthread_exit.

Все потоки в процессе совместно используют одни сегменты данных и кода. Когда один поток записывает данные в глобальные переменные в процессе, остальные потоки сразу же видят эти изменения. Если какой-либо поток вызывает функцию exit или exec, то завершаются все потоки и сам процесс. Поэтому завершающийся поток, если он не хочет разрушить процесс, в котором выполняется, должен вызывать функцию pthread_exit.

Поток может изменить свою сигнальную маску с помощью функции pthread_sigmask. Сигнал, передаваемый процессу, получат все потоки, которые не замаскировали его. Поток может посылать сигналы в другие потоки этого же процесса, используя функцию pthread_kill, но не может посылать сигналы в потоки другого процесса, так как уникальность идентификаторов потоков не распространяется на другие процессы.

Потоку присваивается целочисленное значение приоритета. Чем больше это значение, тем чаще планируемое выполнение потока. Значение приоритета потока можно запросить с помощью функции pthread_attr_getschedparam и изменить с помощью функции pthread_attr_setschedparam. Поток может намеренно передать выполнение другим потокам с таким же приоритетом; для этого используется функция sched_yield. Кроме того, поток может ожидать завершения другого потока и получить его код возврата с помощью функции pthread_join.

Потоки бывают присоединяемые (joinable) и отсоединенные (detached). Различия между ними заключаются в управлении ресурсами по завершению потока. Присоединяемый поток после своего завершения не освобождает память до вызова pthread_join, который освобождает всю занимаемую память (стек и т.п.) и возвращает результат выполнения потока. Отсоединенный поток этого не требует – все ресурсы возвращаются системе непосредственно по его завершению, узнать результат в таком случае невозможно ввиду того, что нет переменной, в которую этот результат может быть сохранен.