Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2010.11.21;
Скачать: CL | DM;

Вниз

Синхронизация доступа к хешу.   Найти похожие ветки 

 
Дмитрий С ©   (2010-08-17 03:55) [0]

Задача теоретическая.
Есть некий хеш (урезанный аналог TStringList): Реализованы только следующие функции:
* Задание значения целиком. (SL.Values[name]:=value)
* Удаление значения (по name). (SL.Delete(SL.IndexOfName(name)))
* Запрос значения (по name). (Value := SL.Values[name])
* Получение списка ключей (SL.Names[0..SL.Count-1]).

Никакие стандартные средства синхронизации недоступны, известно лишь, что задание значения одновременно двумя потоками не разрушает значение (записывается значение одного из этих потоков).

Есть особое значение хеша: Data=... Необходимо организовать синхронизацию доступа к этому значению (как при использовании критических секций). Т.е. у  любого потока должна быть возможность монопольно считать данные, обработать, записать обратно.

Возможно ли это?


 
Palladin ©   (2010-08-17 05:29) [1]


> задание значения одновременно двумя потоками не разрушает
> значение

Проблема параллельного доступа отнюдь не в записи, а в чтении значения. Основная задача параллельного программирования, заблокировать изменения на время чтения значения, которое имеет место в данное время в данном месте. Это как железная дорога. Поезд нельзя пустить по одноколейке с будущим разветвлением на двуколейку не зная на какой путь отправился впереди идущий.


 
Palladin ©   (2010-08-17 05:30) [2]

Блин, слабоватый пример получился )



Страницы: 1 вся ветка

Текущий архив: 2010.11.21;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.006 c
2-1283085939
guest
2010-08-29 16:45
2010.11.21
listbox


2-1282711841
sadd
2010-08-25 08:50
2010.11.21
инсталляция сервиса


6-1229416006
Я только учусь
2008-12-16 11:26
2010.11.21
Подсчет трафика


2-1282601157
XLMD
2010-08-24 02:05
2010.11.21
чтение файлов или бесовщина


15-1281383797
М. Береговой
2010-08-09 23:56
2010.11.21
Будет землетряс или не будет? :-)