Изменения документа Tools.Collections

Редактировал(а) Alexandr Fokin 2023/01/11 15:18

<
От версии < 10.5 >
отредактировано Alexandr Fokin
на 2022/10/04 17:03
К версии < 10.7 >
отредактировано Alexandr Fokin
на 2022/10/04 17:18
>
Изменить комментарий: К данной версии нет комментариев

Комментарий

Подробности

Свойства страницы
Содержимое
... ... @@ -1,16 +1,18 @@
1 1  Репозиторий: [[git repo>>https://git.denhome.ru/Repository/Detail/51601bfd-6f2c-40d8-88bb-f2724b294431]]
2 2  Platform: NetStandart 1.1
3 3  
4 -Данный проект реализует 2 коллекции.
5 -Коллекции представляют из себя Key Value хранилище, являются потокобезопасными. (В основе лежит ConcurrentDictionary)
6 -Для обеспечения оптимистичной блокировки в LinkStorage используется специальный item с полем Stamp, по которому проверяется не был ли изменен элемент во время операции.
7 -(Подробнее смотри ConcurrentDictionary)
4 +Проект реализует набор коллекций.
8 8  
9 9  ----
10 10  
11 -**1) LinkItemDictionary**
8 +==== 1) LinkItemDictionary ====
9 +
10 +Коллекция представляют из себя KeyValue хранилище, является потокобезопасным. (В основе лежит [[ConcurrentDictionary>>Разработка.NET.C#.Коллекции.Concurrent.ConcurrentDictionary.WebHome]], [[Удаление по условию>>Разработка.NET.C#.Коллекции.Concurrent.ConcurrentDictionary.Удаление по условию.WebHome]])
11 +Для обеспечения оптимистичной блокировки в LinkStorage используется специальный item с полем Stamp, по которому проверяется не был ли изменен элемент во время операции.
12 +
12 12  Интерфейс:
13 13  
15 +|Метод|(% style="width:859px" %)Параметры|(% style="width:528px" %)Описание
14 14  |AddLink|(% style="width:859px" %)(((
15 15  |TKey key|ключ
16 16  |Func<TKey, TData> addFactory|фабрика для нового значения
... ... @@ -39,16 +39,12 @@
39 39  При AddLink, помимо увеличения счетчика в HashSet записи добавляется ссылающийся объект.
40 40  При RemoveLink, помимо уменьшения счетчика из HashSet удаляется ссылающийся объект.
41 41  
42 -Ссылки:
43 -[[Разработка/NET/C#/ConcurrentDictionary>>https://wiki.denhome.ru/bin/view/Разработка/NET/C%23/ConcurrentDictionary/]]
44 -https://stackoverflow.com/questions/39679779/how-to-achieve-remove-if-functionality-in-net-concurrentdictionary
45 -
46 46  ----
47 47  
48 48  **3) SortedDictionarySortKeyItemKey**
49 49  
50 50  Класс SortedDictionarySortKeyItemKey выступает в роли надстройки над SortedDictionary. Он позволяет одновременно использовать 2 типа ключей - TSortKey, TItemKey. В таком случае индексатор SortedDictionary будет работать по ключу TItemKey, а порядок элементов в SortedDictionary будет идти по TSortKey.
51 -Также, параметр TSortKeyIsUnique позволяет указать, допусаеются ли одинаковые TSortKey для разных значений TItemKey.
49 +Также, параметр TSortKeyIsUnique позволяет указать, допускаются ли одинаковые TSortKey для разных значений TItemKey.
52 52  
53 53  ----
54 54  
... ... @@ -55,7 +55,7 @@
55 55  **4) Tools.Collections.Concurrent.AsyncBuffer**
56 56  
57 57  Содержит коллекцию, выступающую в роли буфера с возможностями:
58 -1) Параллельная запись в буфер. (Запись в буфер ведеться по одному элементу)
56 +1) Параллельная запись в буфер. (Запись в буфер ведется по одному элементу)
59 59  2) Параллельное чтение элементов из буфера, каждый потребитель получает уникальные значения из буфера. В случае, если буфер пуст, то потребитель может асинхронно ожидать поступление нового элемента в буфер.
60 60  У буфера есть параметр RecommendedMaxSize, значение которого учитывается в методе TryAdd, но дополнительно не блокирует хранилище и счетчик Size, поэтому, при параллельной записи, фактический размер буфера может превысить значение RecommendedMaxSize на несколько элементов.
61 61