|
31 / 21 / 10
Регистрация: 08.10.2017
Сообщений: 181
|
|
Программа с управляющим потоком и потоками-подчинёнными04.06.2019, 20:44. Показов 1189. Ответов 11
Было необходимо распараллелить вычисления в написанной ранее программе, пришёл к такой схему: есть главный поток; он может порождать новые потоки, которые будут ответственны за вычисления, с некоторыми параметрами при их запуске, сможет просматривать состояние всех потоков, принимать возвращаемые вычислительными потоками значения, сможет также избавляться от уже отработавших потоков, освобождая место под новые. Каждому из вычислительных потоков нужно будет одновременно обращаться к одному и тому же массиву для чтения из него. Я в параллельном программировании совсем новичок, потому не знаю, куда смотреть: в сторону mutex, semaphore или threading (ну или еще куда-то, куда я не знаю). И соответственно, где можно почитать про такого рода управление потоками через главный "надзирающий" поток?
0
|
|
| 04.06.2019, 20:44 | |
|
Ответы с готовыми решениями:
11
Как сделать чтобы поток вызванный дочерним потоком не перебивался другими потоками? С потоком программа работает как и без него Полевой транзистор с управляющим PN-переходом JFET |
|
1152 / 860 / 263
Регистрация: 30.04.2009
Сообщений: 3,603
|
|
| 08.06.2019, 21:05 | |
|
http://www.albahari.com/threading/
читаем, еще раз читаем, примеры пишем, что непонятно - спрашиваем.
2
|
|
|
31 / 21 / 10
Регистрация: 08.10.2017
Сообщений: 181
|
|
| 17.06.2019, 11:12 [ТС] | |
|
Начал этим заниматься, появился вопрос: есть матрица n x n. Создаю n потоков для того, чтобы писать в матрицу по столбцам, т.е. они друг с другом не контактируют и конфликтуют. Однако, матрица оказывается заполненной не полностью - то 2 потока её заполняют, а остальные даже не трогают, то 3, то 4... Полностью она никогда не заполняется, и причины для этого я не вижу. В чём может быть причина?
0
|
|
|
1152 / 860 / 263
Регистрация: 30.04.2009
Сообщений: 3,603
|
|
| 17.06.2019, 11:50 | |
|
0
|
|
|
31 / 21 / 10
Регистрация: 08.10.2017
Сообщений: 181
|
||||||
| 17.06.2019, 19:25 [ТС] | ||||||
0
|
||||||
|
1152 / 860 / 263
Регистрация: 30.04.2009
Сообщений: 3,603
|
||
| 17.06.2019, 19:58 | ||
|
К тому же создавать потоки подобным образом без ограничения их количества это очень неэффективно. Для этой задачи лучше использовать метод Parallel.For. Там есть и ожидание выполнения всех потоков и ограничение их количества согласно количеству потоков процессора.
0
|
||
|
31 / 21 / 10
Регистрация: 08.10.2017
Сообщений: 181
|
||
| 17.06.2019, 20:27 [ТС] | ||
|
И чем плохо то, что вызывающий поток не будет дожидаться завершения выполнения своих детищ? И тогда вопрос до кучи. Как лучше всего убивать поток? Читал про thread.Interrupt() и thread.Abort(), и одни говорят, что надо использовать первый способ, вторые говорят, что второй. Как тогда?
0
|
||
|
1152 / 860 / 263
Регистрация: 30.04.2009
Сообщений: 3,603
|
||||
| 17.06.2019, 22:16 | ||||
|
При этом для запуска требуется выполнить 1000+ процессорных инструкций и выделить 1MB памяти под стэк потока, которая будет занята пока поток не завершится.
0
|
||||
|
31 / 21 / 10
Регистрация: 08.10.2017
Сообщений: 181
|
||
| 18.06.2019, 13:28 [ТС] | ||
|
И есть какой-то эффективный способ распараллеливания рекурсивных алгоритмов методами С#?
0
|
||
|
1152 / 860 / 263
Регистрация: 30.04.2009
Сообщений: 3,603
|
||||||||
| 18.06.2019, 15:02 | ||||||||
Interrupt или Abort используются для прерывания работы потока извне когда работа еще не завершена.Если есть ветвления которые не зависят от расчетных данных из других веток, то можно распаралелить.
0
|
||||||||
|
31 / 21 / 10
Регистрация: 08.10.2017
Сообщений: 181
|
|
| 26.06.2019, 18:14 [ТС] | |
|
Написал то, что хотел. Программа отрабатывает, но выдаёт не всегда (~70% случаев) не то, что ожидалось. Есть ли какой-то способ отладки многопоточных программ? При отладке через точку останова нажатие F11/F10 не даёт ничего, так как отладка скачет между потоками, и невозможно понять, какой поток чем занят в данный момент времени.
0
|
|
| 26.06.2019, 18:14 | |
|
Помогаю со студенческими работами здесь
12
Программа с потоками 1-ая программа с потоками Программа с параллельными потоками на C# Программа для работы с потоками Сложность с потоками: программа виснет Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта
Симптом:
После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
|
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
|
Новый ноутбук
volvo 07.12.2025
Всем привет.
По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне:
Ryzen 5 7533HS
64 Gb DDR5
1Tb NVMe
16" Full HD Display
Win11 Pro
|
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
|
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
|
|
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов
На странице:
https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/
нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
|
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов.
. . .
|
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
|
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
|
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут.
В век Веб все очень привыкли к дизайну Single-Page-Application .
Быстренько разберем подход "на фреймах".
Мы делаем одну. . .
|