PDA

Просмотр полной версии : Потоки и процессы.


nerezus
28.10.2007, 16:16
Вырезано из темы.



Процесс не является тредом, т.к. разная область памяти. Поэтому форк(новый процесс) не является тредом.

Ni0x
28.10.2007, 16:24
Две замечательные статьи про процессы и треды в nix и windows системах:
http://uinc.ru/articles/34/
http://uinc.ru/articles/38/
В свое время очень помогли мне.

_Great_
28.10.2007, 16:25
ТС: читаешь

http://en.wikipedia.org/wiki/Light-weight_process
http://en.wikipedia.org/wiki/Light_Weight_Kernel_Threads

и просматриваешь http://www.google.ru/search?q=light+weight+process

ZaCo
28.10.2007, 18:50
2_Great_ английского не особо знаю, но пусть потоки реализованы как процессы. только так можно говорить про потоки ядра; я так понимаю на уровне ос потоки действительно создаются как процессы, но их таблицы, пространства и тд просто являются одним целым. вот только fork, как читай единственный механизм создания процесса пользовательского уровня, создает заранее именно НЕ зависимые друг от друга процессы. так я к чему клоню - мы не говорим о том чем занимается ядро, мы говорим о том, что одним доступным вызовом fork ты просто так процессы не объединишь - придется использовать как-то разделяемую память (я не про shmmat и тд), что-то делать со всеми дескрипторами и тд и имхо этого достичь средствами посикс ил сисв апи нельзя. а стало быть выжать из fork'а поток не получится. так что пользовательский по крайней мере posix-потоки не имеют ничего общего с fork-вызванными процессами..

groundhog
28.10.2007, 19:21
ZaCo, вообще речь изначально была о поддержке потоков в языке PHP. Но как-то плавно nerezus её перевёл в русло "а существуют ли потоки в Unix". Вы хоть одно разумное объяснение приведите - почему форканый процесс не может считаться потоком, и почему все Unix программисты считают его потоком? Нашлись только два человека, которые с пеной у рта доказывают бредовость Unix архитектуры.

По поводу "потоков" в PHP: http://ru.php.net/manual/ru/ref.pcntl.php. Хоть какие, но это потоки, и не надо тут строить параллели с виндой. Или тут кто-то будет спорить что в POSIX не существует средств для "общения" потоков? В чём сейчас спор?

ZaCo
28.10.2007, 19:30
обычно под потоком понимается posix-поток, то есть вызванный функцией pthread_create. это и имелось ввиду. итак, posix-поток выполняется в адресном пространстве процесса, который его создал. я склонен считать греата правым в том, что ядерные потоки действительно ничем от процессов не отличаются. причем процесс чье адресное пространство и тп является единым с другим могут считаться двумя потоками, а не раздельными процессами.

>>Вы хоть одно разумное объяснение приведите - почему форканый процесс не может
>>считаться потоком, и почему все Unix программисты считают его потоком?

я все написал в первом сообщении этой темы. и почему ты говоришь сейчас за всех Unix-программистов?

>>Нашлись только два человека, которые с пеной у рта
>>доказывают бредовость Unix архитектуры.

чего?

--
под новым процессом же понимается дочерний процесс после вызова fork, потому что только он доступен из приведенного расширения php. про формы rfork никто ничего не говорит хотя бы потому что это не есть стандарт.

Dude03
30.10.2007, 16:23
Но как-то плавно nerezus её перевёл в русло "а существуют ли потоки в Unix". Вы хоть одно разумное объяснение приведите - почему форканый процесс не может считаться потоком, и почему все Unix программисты считают его потоком? Нашлись только два человека, которые с пеной у рта доказывают бредовость Unix архитектуры.

В различных unix-like ОС реализация такой фигни(абстракции) как поток различная. Поэтому вопросы типо "а существует ли в Unix поток" выглядят немного глупо.

Применительно к реализации процессов и потоков в linux: Процесс == поток (на уровне ядра их представляет одна и та же структура)

За все остальные "юнихи" говорить не буду=)


...и не надо тут строить параллели с виндой

+1

groundhog
30.10.2007, 16:45
В различных unix-like ОС реализация такой фигни(абстракции) как поток различная. Поэтому вопросы типо "а существует ли в Unix поток" выглядят немного глупо.
Я надюсь, что nerezus всё таки разобрался в этих понятиях относительно Unix-систем. Просто если сейчас начнётся обсуждение различного рода обёрток для реализации суперфункциональности в плане "потоков" , то тут форума не хватит чтобы каждый высказал своё мнение... :)

DWORD
31.10.2007, 10:48
Потоки есть потоки. Каждый поток - это просто отдельный программный код со своим окружением (хотя может так случиться что код будет исполняться в случайном окружении, т.е. в контексте случайного потока, тогда у этого кода вообще нет своего потока). Процессы это абстракция, каждый волен сам придумывать что называть процессом и в каждой ОС сооствественно они реализованы по-своему. Поток может существовать вообще без процесса.

DWORD
03.11.2007, 15:14
Протеус, истолкуй здесь свою точку зрения. Ты оставил комментарий в моей "репутации". Я не знаю, причем здесь Рихтер, теория и практика многозадачности не есть реализация операционной системы windows, так причем же здесь Рихтер? И что конкретно мне нужно почитать и в какой его книге?

da_ff
03.11.2007, 16:42
может так случиться что код будет исполняться в случайном окружении, т.е. в контексте случайного потока, тогда у этого кода вообще нет своего потока

от того что код будет добавлен в другой процес нового процесса не появится
Процессы это абстракция, каждый волен сам придумывать что называть процессом

процесс это обьект ядра соответствующего типа и связанная с ним область памяти, при его создании ему в соответствие ставится первичный поток, помоему нет никакой абстракции

DWORD
03.11.2007, 19:19
Да нет почему, ему еще может все что угодно ставиться в соответствие (и ставится)

nerezus
03.11.2007, 20:09
Вы хоть одно разумное объяснение приведите - почему форканый процесс не может считаться потоком Потому что это процесс, а не поток. И в этом процессе есть 1 поток. Почитай Advanced Unix Programming, глава 5.17.1: потоки имеют разные стеки и последовательности комманд, но глобальные данные, ресурсы(файлы и т.д.) общие.

Dude03
03.11.2007, 22:38
Потоки есть потоки. Каждый поток - это просто отдельный программный код со своим окружением (хотя может так случиться что код будет исполняться в случайном окружении, т.е. в контексте случайного потока, тогда у этого кода вообще нет своего потока). Процессы это абстракция, каждый волен сам придумывать что называть процессом и в каждой ОС сооствественно они реализованы по-своему. Поток может существовать вообще без процесса.
так же как и процесс может существовать без потока=).
В любом случае и поток, и процесс это абстракции.

nerezus
03.11.2007, 22:52
так же как и процесс может существовать без потока=). В каждом процессе есть как минимум 1 нить ;)

_Great_
03.11.2007, 23:07
Потому что это процесс, а не поток. И в этом процессе есть 1 поток. Почитай Advanced Unix Programming, глава 5.17.1: потоки имеют разные стеки и последовательности комманд, но глобальные данные, ресурсы(файлы и т.д.) общие.
У них вообще АП общее.

так же как и процесс может существовать без потока=).
и что же он интересно будет делать.
сразу скажу, такой изврат, как EPROCESS с Flags.ProcessExiting==TRUE в Windows мы не рассматриваем.