Jump to content

pthreads

(Перенаправлено из потоков POSIX )

В вычислениях , потоки POSIX , широко известные как pthreads , представляют собой модель выполнения , существующую независимо от языка программирования а также модель параллельного выполнения . Это позволяет программе управлять несколькими различными потоками работы, которые перекрываются во времени. Каждый поток работы называется потоком , а создание и управление этими потоками достигается путем вызовов API POSIX Threads . POSIX Threads — это API, определенный .1c Института инженеров по электротехнике и радиоэлектронике (IEEE) стандартом POSIX , расширения потоков (IEEE Std 1003.1c-1995) .

Реализации API доступны во многих Unix-подобных POSIX-совместимых операционных системах, таких как FreeBSD , NetBSD , OpenBSD , Linux , macOS , Android , [ 1 ] Solaris , Redox и AUTOSAR Adaptive, обычно поставляемые в виде библиотеки libpthread . Также существуют реализации DR-DOS и Microsoft Windows : в подсистеме SFU/SUA , которая обеспечивает собственную реализацию ряда API-интерфейсов POSIX, а также в сторонних пакетах, таких как pthreads-w32 . [ 2 ] который реализует pthreads поверх существующего Windows API .

Содержание

[ редактировать ]

pthreads определяет набор C. языка программирования типов , функций и констант Он реализован с помощью pthread.h потоков заголовок и библиотека .

Существует около 100 процедур потоков, все с префиксами. pthread_ и их можно разделить на пять групп:

POSIX API семафоров работает с потоками POSIX, но не является частью стандарта потоков, поскольку он определен в стандарте POSIX.1b, Расширения реального времени (IEEE Std 1003.1b-1993) . Следовательно, семафорные процедуры имеют префикс sem_ вместо pthread_.

Пример, иллюстрирующий использование pthreads в C:

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

#define NUM_THREADS 5

void *perform_work(void *arguments){
  int index = *((int *)arguments);
  int sleep_time = 1 + rand() % NUM_THREADS;
  printf("Thread %d: Started.\n", index);
  printf("Thread %d: Will be sleeping for %d seconds.\n", index, sleep_time);
  sleep(sleep_time);
  printf("Thread %d: Ended.\n", index);
  return NULL;
}

int main(void) {
  pthread_t threads[NUM_THREADS];
  int thread_args[NUM_THREADS];
  int i;
  int result_code;
  
  //create all threads one by one
  for (i = 0; i < NUM_THREADS; i++) {
    printf("In main: Creating thread %d.\n", i);
    thread_args[i] = i;
    result_code = pthread_create(&threads[i], NULL, perform_work, &thread_args[i]);
    assert(!result_code);
  }

  printf("In main: All threads are created.\n");

  //wait for each thread to complete
  for (i = 0; i < NUM_THREADS; i++) {
    result_code = pthread_join(threads[i], NULL);
    assert(!result_code);
    printf("In main: Thread %d has ended.\n", i);
  }

  printf("Main program has ended.\n");
  return 0;
}

Эта программа создает пять потоков, каждый из которых выполняет функцию Perform_work , которая выводит уникальный номер этого потока в стандартный вывод. Если бы программист хотел, чтобы потоки взаимодействовали друг с другом, для этого потребовалось бы определить переменную вне области действия любой из функций, сделав ее глобальной переменной . Эту программу можно скомпилировать с помощью компилятора gcc следующей командой:

gcc pthreads_demo.c -pthread -o pthreads_demo

Вот один из многих возможных результатов запуска этой программы.

In main: Creating thread 0.
In main: Creating thread 1.
In main: Creating thread 2.
In main: Creating thread 3.
Thread 0: Started.
In main: Creating thread 4.
Thread 3: Started.
Thread 2: Started.
Thread 0: Will be sleeping for 3 seconds.
Thread 1: Started.
Thread 1: Will be sleeping for 5 seconds.
Thread 2: Will be sleeping for 4 seconds.
Thread 4: Started.
Thread 4: Will be sleeping for 1 seconds.
In main: All threads are created.
Thread 3: Will be sleeping for 4 seconds.
Thread 4: Ended.
Thread 0: Ended.
In main: Thread 0 has ended.
Thread 2: Ended.
Thread 3: Ended.
Thread 1: Ended.
In main: Thread 1 has ended.
In main: Thread 2 has ended.
In main: Thread 3 has ended.
In main: Thread 4 has ended.
Main program has ended.

POSIX-потоки для Windows

[ редактировать ]

Windows не поддерживает стандарт pthreads изначально, поэтому проект Pthreads4w стремится предоставить переносимую реализацию оболочки с открытым исходным кодом. Его также можно использовать для переноса программного обеспечения Unix (которое использует pthreads) с небольшими изменениями или без них на платформе Windows. [ 4 ] Pthreads4w версия 3.0.0 [ 5 ] или более поздняя версия, выпущенная под лицензией Apache Public License v2.0, совместима с 64-битными или 32-битными системами Windows. Версия 2.11.0, [ 6 ] выпущенный по лицензии LGPLv3, также совместим с 64-битными или 32-битными версиями.

Проект Mingw-w64 также содержит реализацию оболочки pthreads, winpthreads , которая пытается использовать больше собственных системных вызовов, чем проект Pthreads4w. [ 7 ]

Подсистема среды Interix, доступная в пакете Службы Windows для UNIX/Подсистема для приложений на базе UNIX, предоставляет собственный порт API pthreads, т.е. не сопоставленный с Win32 API, а встроенный непосредственно в интерфейс системных вызовов операционной системы . [ 8 ]

См. также

[ редактировать ]
  1. ^ «libc/bionic/pthread.c — платформа/bionic — Git в Google» . android.googlesource.com .
  2. ^ «Pthread Win-32: Уровень соответствия стандартам» . 22 декабря 2006 г. Архивировано из оригинала 11 июня 2010 г. Проверено 29 августа 2010 г.
  3. ^ «pthread.h(0p) — страница руководства Linux» . Проверено 18 декабря 2022 г.
  4. ^ Харт, Джонсон М. (21 ноября 2004 г.). «Эксперименты с библиотекой Pthreads с открытым исходным кодом и некоторые комментарии» . Архивировано из оригинала 30 августа 2010 г. Проверено 29 августа 2010 г.
  5. ^ Файл: pthreads4w-code-v3.0.0.zip — источник для pthreads4w v3.0.0.
  6. ^ Файл: pthreads4w-code-v2.11.0.zip — Источник pthreads4w v2.11.0.
  7. ^ см. http://locklessinc.com/articles/pthreads_on_windows , откуда он был первоначально получен.
  8. ^ «Глава 1: Введение в службы Windows для UNIX 3.5» . 5 декабря 2007 г.

Дальнейшее чтение

[ редактировать ]
[ редактировать ]
Arc.Ask3.Ru: конец переведенного документа.
Arc.Ask3.Ru
Номер скриншота №: af5309fe0dca284ca2b0c8eb658fed25__1723043640
URL1:https://arc.ask3.ru/arc/aa/af/25/af5309fe0dca284ca2b0c8eb658fed25.html
Заголовок, (Title) документа по адресу, URL1:
pthreads - Wikipedia
Данный printscreen веб страницы (снимок веб страницы, скриншот веб страницы), визуально-программная копия документа расположенного по адресу URL1 и сохраненная в файл, имеет: квалифицированную, усовершенствованную (подтверждены: метки времени, валидность сертификата), открепленную ЭЦП (приложена к данному файлу), что может быть использовано для подтверждения содержания и факта существования документа в этот момент времени. Права на данный скриншот принадлежат администрации Ask3.ru, использование в качестве доказательства только с письменного разрешения правообладателя скриншота. Администрация Ask3.ru не несет ответственности за информацию размещенную на данном скриншоте. Права на прочие зарегистрированные элементы любого права, изображенные на снимках принадлежат их владельцам. Качество перевода предоставляется как есть. Любые претензии, иски не могут быть предъявлены. Если вы не согласны с любым пунктом перечисленным выше, вы не можете использовать данный сайт и информация размещенную на нем (сайте/странице), немедленно покиньте данный сайт. В случае нарушения любого пункта перечисленного выше, штраф 55! (Пятьдесят пять факториал, Денежную единицу (имеющую самостоятельную стоимость) можете выбрать самостоятельно, выплаичвается товарами в течение 7 дней с момента нарушения.)