![]() |
|
|
Регистрация | << Правила форума >> | FAQ | Пользователи | Календарь | Поиск | Сообщения за сегодня | Все разделы прочитаны |
![]() |
|
Опции темы | Поиск в этой теме | Опции просмотра |
#1
|
|||
|
|||
![]() Доброго времени суток. Вопрос, как мне кажется простой, но ответ найти не могу. Как создать уникальный поток? Задача состоит в создании массива, например, k[i,j], где j номер потока, т.е. существует задача, что-то посчитав скинуть в массив, а поскольку потоки постоянно переключаются между собой, а массив является глобальной переменной, конечное решение может быть не корректно, например, если j определять при создании потока.
|
#2
|
|||
|
|||
![]() Непонятно, чего все-таки надо.
Если у тебя расчет элемента не зависит от других, то никаких проблем, за исключением большого кол-ва потоков если массив большой, я не вижу. А если зависит, то фактически разбиение на потоки бесполезно, бо как все последующие потоки будут ждать предыдущие. Если же разговор идет о пуле потоков, то обычно это решается с помощью одного потока-координатора, который из списка задач дает работу некоторому кол-ву потоков. Т.е. в твоем случае назначает j для определенного потока. Ну и про синхронизацию потоков надо не забывать (synchronize и CriticalSection). |
#3
|
|||
|
|||
![]() lmikle. У меня существует программа на одном потоке с глобальными переменными в области моделирования работы паровой турбины, детали можно опустить. Существует определенная последовательность процедур. Я мог бы эту последовательность в отдельных юнитах прописать со своими переменными, но думаю, что это бессмысленно. Данное определение потока сможет позволить создать в одних и тех же процедурах разные вычисления, т.к. переменные будут однозначно принадлежать нужному потоку, конечно необходимость синхронизировать не отпадет, но простой синхронизацией не получается решить задачу, т.к. переменная j потока определяется не корректно, происходит путаница. Глобальные переменные перезаписываются. Если делать ожидание пока один поток досчитает все переменные, тогда использовать два потока бессмысленно, фактически решаться будет в одном потоке. Поэтому я и пришел к выводу, что нужны массивы. Например, сейчас переменная k:real, заменив на k: array [1..4] of integer, или создав динамические массивы, чтобы количество потоков можно было организовать произвольным, задача бы решилась.
|