![]() |
Модераторы: Snowy, bartram, MetalFan, bems, Poseidon, Riply |
![]() ![]() ![]() |
|
Spike |
|
|||
![]() Шустрый ![]() Профиль Группа: Участник Сообщений: 52 Регистрация: 5.7.2005 Где: Протвино МО Репутация: нет Всего: 1 |
Всем привет!
Было не просто... проект не маленький и в-общем-то работающий, внедрение Interlocked-функций субъективно улучшило производительность (конечно, параллельно сделан небольшой рефакторинг и оптимизация). Да, поизучал, поэкспериментировал с TMultiReadExclusiveWriteSynchronizer - не совсем то что нужно, насколько я понял - если некий поток хочет что-то записать, он будет ждать пока читающие потоки закончат свои дела. С Interlocked-функциями интереснее - пишущий поток даже не думает что там кто читает, пишет когда нужно и все. Моя реализация аналогична примеру от bems. Для читающих потоков создается образ-копия данных, а по завершению создания образа проверяется версия, если не та - переделать. Пишущий поток просто ломится в данные, меняет их и увеличивает версию. Получилось красиво и универсально ![]() P.S.: вот еще полезное
|
|||
|
||||
![]() ![]() ![]() |
Правила форума "Delphi: WinAPI и системное программирование" | |
|
Запрещено: 1. Публиковать ссылки на вскрытые компоненты 2. Обсуждать взлом компонентов и делиться вскрытыми компонентами
Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Snowy, bartram, MetalFan, bems, Poseidon, Rrader, Riply. |
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | Delphi: WinAPI и системное программирование | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |