![]() |
Модераторы: Partizan, gambit |
![]() ![]() ![]() |
|
mr.DUDA |
|
|||
![]() 3D-маньяк ![]() ![]() ![]() ![]() Профиль Группа: Экс. модератор Сообщений: 8244 Регистрация: 27.7.2003 Где: город-герой Минск Репутация: 110 Всего: 232 |
Не решит, т.к. lock работает в рамках одного процесса. Насколько я понял из объяснения, нужно синхронизировать отдельные процессы (а lock блокирует потоки). -------------------- ![]() |
|||
|
||||
YuryS |
|
|||
Новичок Профиль Группа: Участник Сообщений: 14 Регистрация: 15.9.2007 Репутация: 1 Всего: 1 |
Ну, во-первых, здесь не сформулировано четко в чем же проблема ? Когда поставлена проблема организовать конвейер, это я понимаю ... Если подразумевается организовать просто взоимодействие 2-ух процессов через общую память (переменную value), то приведенное решение страдает тем же недостатком, о чем спрашивалось ранее, т.е., придется в цикле все время крутить метод ReadWrite, чтобы проверять флаг read. Наконец, всё-таки правильней не изобретать велосипед, а освоить уже имеющиеся средства, чтобы тратить время собственно на задачу, а не на вспомогательные параллельные штучки. |
|||
|
||||
tol05 |
|
|||
![]() Эксперт ![]() ![]() ![]() Профиль Группа: Участник Клуба Сообщений: 1632 Регистрация: 21.12.2006 Где: Харьков Репутация: 63 Всего: 170 |
ИМХО это называется распределенное приложение. И разрабатывать эти три процесса нужно как remoting приложения. Сделать возможность генерирования "подчиненными" процессами событий типа Set и Reset (начала и конец блокировки ресурса). Один процесс занимает ресурс и генерирует событие для блокировки другого процесса. По окончанию работы он генерирует событие для снятия блокировки того, другого, процесса. -------------------- На хорошей работе и сны хорошие снятся. |
|||
|
||||
YuryS |
|
|||
Новичок Профиль Группа: Участник Сообщений: 14 Регистрация: 15.9.2007 Репутация: 1 Всего: 1 |
||||
|
||||
QryStaL |
|
|||
![]() Intellectual feast ![]() ![]() Профиль Группа: Участник Сообщений: 914 Регистрация: 30.11.2005 Репутация: 14 Всего: 32 |
YuryS, Remoting как раз и нужен для взаимодействия между процессами и доменами приложений. С этой точки зрения физической размещение процессов роли не играет.
-------------------- I don't need a reason being who I am... |
|||
|
||||
YuryS |
|
|||
Новичок Профиль Группа: Участник Сообщений: 14 Регистрация: 15.9.2007 Репутация: 1 Всего: 1 |
Все 3 процесса работают в рамках одного приложения, поэтому домены здесь не причем. Remoting, по определению, используется для взаимодействия процессов, расположенных на разных компах. |
|||
|
||||
mr.DUDA |
|
|||
![]() 3D-маньяк ![]() ![]() ![]() ![]() Профиль Группа: Экс. модератор Сообщений: 8244 Регистрация: 27.7.2003 Где: город-герой Минск Репутация: 110 Всего: 232 |
Терминология хромает. Процесс и приложение - синонимы. Ваш "процесс" в общепринятой терминологии называется "поток". Вот для синхронизации потоков оператор lock - именно то что нужно. -------------------- ![]() |
|||
|
||||
tol05 |
|
|||
![]() Эксперт ![]() ![]() ![]() Профиль Группа: Участник Клуба Сообщений: 1632 Регистрация: 21.12.2006 Где: Харьков Репутация: 63 Всего: 170 |
А откуда это "определение"? YuryS, у тебя неправильная информация ![]() ремоутинг - это технология кросс-доменного взаимодействия (или даже кросс-контекстного), а где расположены эти домены - в одном приложении, в разных процессах, на разных машинах в укромных уголках земного шара, или даже на планете "Кргмн-мняу-мняу" - это безразлично. Думаю, тебе стоит ознакомится с этой технологией поподробнее. -------------------- На хорошей работе и сны хорошие снятся. |
|||
|
||||
mr.DUDA |
|
|||
![]() 3D-маньяк ![]() ![]() ![]() ![]() Профиль Группа: Экс. модератор Сообщений: 8244 Регистрация: 27.7.2003 Где: город-герой Минск Репутация: 110 Всего: 232 |
Для многопоточного приложения заводить домены на каждый поток не нужно.
-------------------- ![]() |
|||
|
||||
YuryS |
|
|||
Новичок Профиль Группа: Участник Сообщений: 14 Регистрация: 15.9.2007 Репутация: 1 Всего: 1 |
||||
|
||||
tol05 |
|
||||
![]() Эксперт ![]() ![]() ![]() Профиль Группа: Участник Клуба Сообщений: 1632 Регистрация: 21.12.2006 Где: Харьков Репутация: 63 Всего: 170 |
mr.DUDA, а с чего вы взяли, что это мультипоточное, а не мультипроцессное приложение? Почему вдруг все стали говорить о потоках? Как я понял автора вопроса (Fieral) - есть независимые процессы. Не потоки...
сначала
а потом уже
что случилось, mr.DUDA? ![]() -------------------- На хорошей работе и сны хорошие снятся. |
||||
|
|||||
mr.DUDA |
|
|||
![]() 3D-маньяк ![]() ![]() ![]() ![]() Профиль Группа: Экс. модератор Сообщений: 8244 Регистрация: 27.7.2003 Где: город-герой Минск Репутация: 110 Всего: 232 |
tol05, автор вопроса не подтвердил и не опровергнул моего предположения о том, что речь идёт о потоках. Пока речь шла о процессах, lock не был применимым вариантом. Для потоков наоборот.
-------------------- ![]() |
|||
|
||||
![]() ![]() ![]() |
Прежде чем создать тему, посмотрите сюда: | |
|
Используйте теги [code=csharp][/code] для подсветки кода. Используйтe чекбокс "транслит" если у Вас нет русских шрифтов. Что делать если Вам помогли, но отблагодарить помощника плюсом в репутацию Вы не можете(не хватает сообщений)? Пишите сюда, или отправляйте репорт. Поставим :) Так же не забывайте отмечать свой вопрос решенным, если он таковым является :) Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, mr.DUDA, THandle. |
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | Общие вопросы по .NET и C# | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |