yigal_s: (Default)
yigal_s ([personal profile] yigal_s) wrote2007-01-24 06:29 pm
Entry tags:

Мультитрединг - как победить дракона

1. Semaphores
2. Monitors (conditional variables).
3. Messages, рандеву, remote calls, actors (пока не разобрался, одно ли это и то же концептуально, или есть разница. Вообще, в принципе, больше "слышал звон", чем "в теме". Потихоньку разберусь)
4. transactional memory - несколько дней назад где-то ссылку на это дело подобрал.

Интересно, есть еще что-то неупомянутое?

-----
Upd: собственно, в списке представлена некоторая линия эволюции (хотя линейной эволюции в реальности, видимо, не было в точности) способов "синхронизации", вернее, написания мультитредного кода.

[identity profile] cmm.livejournal.com 2007-01-24 05:18 pm (UTC)(link)
> Интересно, есть еще что-то неупомянутое?

единственный по-настоящему надёжный вариант — не приставать к дракону вообще.

на крайняк использовать shared memory между процессами, для чётко определённых вещей.

короче: отказаться от модели, в которой shared memory является выбором по умолчанию.

[identity profile] cmm.livejournal.com 2007-01-24 05:34 pm (UTC)(link)
> несколькими компьютерами к общей базе данных - проблемы, в общем, по большому счету те же.

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

[identity profile] cmm.livejournal.com 2007-01-24 05:51 pm (UTC)(link)
я утверждаю примерно следующее, на самом деле: все возможные модели безопасного и постижимого для человеческого ума параллельного доступа к памяти так или иначе сводятся к двум вещам:

* объявлению параллельного доступа к константным данным простой оптимизацией (то есть с точки зрения семантики клиентского кода, абсолютно параллельно где эти данные сидят: все в одном месте или в виде кучи копий).

* созданию у изменяющего данные кода иллюзии параллельного доступа и чёткой синхронизации (то бишь убиранию параллельности) этого дела "под капотом".

[identity profile] cmm.livejournal.com 2007-01-24 07:02 pm (UTC)(link)
ну собственно transactional memory с аппаратной поддержкой — это именно вот оно.
гениальная фишка, на самом деле.

[identity profile] cmm.livejournal.com 2007-01-24 09:02 pm (UTC)(link)
> проблемы написания блокирующего (а не транзакционного) мультитрединга было бы правильно загнать в какую-то математическую теорию.

загнать-то можно (типа CPU + память = такая большая машина состояний, далее везде), толку только с таких теорий.  практикующие теоретики (хихи) предпочитают атаковать проблему формализации со стороны упрощения моделей, а не совершенствования теорий — видимо, у них есть на это хорошие причины. :)

> Вы, кстати, не знакомы вот с этой работой?

ой, нет.  я на самом деле в математике очень слаб...

[identity profile] cmm.livejournal.com 2007-01-24 05:38 pm (UTC)(link)
существование чёткой каузальной зависимости между привычкой наступать на грабли и черепно-мозговым травматизмом тоже не доказано.  в силу хотя бы неоднозначного направления каузации.

и тем не менее. :)

[identity profile] cmm.livejournal.com 2007-01-24 05:44 pm (UTC)(link)
в том-то и дело: для реляционных баз данных проблема решена: давно, строго и формально (если я ничего не путаю, да).

[identity profile] cmm.livejournal.com 2007-01-24 05:53 pm (UTC)(link)
написание функции для вычисления факториала требует программирования, при котором в принципе неизбежны баги.  но чёткое знание того что мы делаем очень помогает.

[identity profile] cmm.livejournal.com 2007-01-24 09:06 pm (UTC)(link)
вообще всё дело в правильных абстракциях.
вот взять то же ядро юникса: это же очень сложная и чудовищно граблесодержащая вещь — включая и грабли параллельного доступа к общим ресурсам, причём не только к памяти!  но экономика предоставляет нам возможность взять готовую реализацию и рассматривать её как чёрный ящик.