170 похожих чатов

Задача. Создать n объектов класса с уникальным свойством, например "Name".

И чтобы при создании/вызове/доступе к этому объекту создавался новый объект, если такого имени не существует и возвращался уже созданный объект, если такое имя уже существует. Тип синглтон, только не для классов, а для объектов с уникальным свойством.
Пока додумался только создавать объекты и засовывать их в словарь, где key будет одновременно и этим уникальным свойством.
Мб кто нибудь сталкивался с подобного рода задачей. Как её лучше всего реализовать. Ну и вообще нужно ли так делать?
Это нужно для решения следующей задачи: есть много связанных между собой структур, нодами которых являются как раз уникальные объекты с уникальным именем. "Планировщик" должен проходит по коллекции этих структур (деревьев), потом проходить по каждой из нод и вызывать update у каждого из объектов, ну и соответственно если объекта с таким именем нет, то создавать его.

17 ответов

4 просмотра

Быстрее словаря для такой задачи ничего нет

Anton-『被遗忘的社会』 Автор вопроса
Phantom
screenshot

я же написал, что со словарём я и сам додумался как сделать

Phantom
screenshot

А зачем тебе тут else?

Anton-『被遗忘的社会』 Автор вопроса
Phantom
Так, что не так?

Изначально хотелось сделать так, чтобы было возможно управлять всем этим используя исключительно свойства объекта. А в варианте со словарём ты как бы дублируешь это свойства ещё в key словаря.

Phantom
screenshot

это че за херня? не проще Dict[key]=value ?

Anton-『被遗忘的社会』 Автор вопроса
Phantom
Как ты это представляешь?

В том и дело, что я не смог себе это представить и спросил тут

Anton 『被遗忘的社会』
В том и дело, что я не смог себе это представить и...

Если в твоей коллекции он null, он не может магическим способом стать не null

Phantom
screenshot

else убери

Mr. N
else убери

Спасибо за бессмысленный доеб, к примеру кода, который я записал за пару секунд

Mr. N
else убери

Тут я с мистером н согласен

Phantom
screenshot

легче просто взять concurrentdictionary, как выше написали

Похожие вопросы

Обсуждают сегодня

я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
короче сгенерила мне эта штука код на ассемблере: struc string val { common local .value dq .value .value: if ~val eq db val end if db 0 } fo...
Vi Chapmann Chapmann
12
Всем привет! Массив вводится с клавиатуры, кол-во элементов неизвестно, поэтому я указал arr db 100 dup(?) С нахождением максимума проблем нет, а вот минимум почему-то всегд...
En Vind Av Sorg
11
#include <stdio.h> int main(void) { int n; scanf("%d", &n); int digits1[n] = {0}; int digits2[n] = {0}; я не могу таким образом заранее массив нулями заполнить?
Linus
12
в сях есть множество как в питоне? для удаление дубликатов
Linus
25
я про форму записи. смысл указывать что 8 байтный регистр 8 байт?
Aiwan \ (•◡•) / _bot
10
читать файл максимально быстро? странный вопрос))
zamtmn
53
Вроде бы вопрос уже заезжанный, но тем не менее У меня есть функция menu() которая выводит набор возможных действий, а затем спрашивает у пользователя что он хотел бы сделать....
David Golovatin
3
Кто создает тут ботов для телеграмм групп ?
Antskup
8
а как бы вылезти из ИО, что то типа IO -> Ether или в какую сторону смотреть ? что то туплю
Fedor
14
Карта сайта