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

Вот есть у меня датакласс @dataclass(frozen=True) class InputFieldsFigure: constructor:

Callable
fields: List[InputFieldRM]
extra: FigureExtra

Мне нужно, чтобы объект был хешируемым, но из-за того, что в fields лежит список, то он таким не является. При этом, мне не хочется заменять список на тапл, поскольку не очень удобно.
Как лучше всего сделать его хешируемым?
Сделать InitVar, в котором бы лежал список, а в пост ините преобразовать в тапл? Или хранить и тапл и список?

15 ответов

23 просмотра

Пометь секвенс, а в постините сделай тапл

Pavel-Павлик Автор вопроса
Tishka17
Пометь секвенс, а в постините сделай тапл

Стоп, для хешируемости нужен же, чтобы датакласс был frozen, а тогда в постините я не могу заменять атрибуты без магии

Ну можно сделать dirty hash, а для исключения изменения пропертей навешать

Pavel-Павлик Автор вопроса
Pavel-Павлик Автор вопроса

В данном кейсе я заменил все список на тапл, но появилась идея, как в таких случаях можно поступать иногда. Внутри FieldRM есть metadata: Mapping. Можно было сделать HashableMapping протокол, но стандартные маппинги никогда хеш не реализуют. Так что я просто выкинул это поле из хеша (благо, датаклассы так позволяют). В данном случае на коллизиях это почти никак не скажется

Pavel-Павлик Автор вопроса

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

Pavel Павлик
Нет, а зачем? Если у поля разная метадата, то это ...

так если у тебя хэш сохранился, но на равенство перестало работать, разве будет словарь корректно это обслуживать?

Pavel Павлик
Не очень понял вопрос

для какой цели тебе хэшируемость?

Tishka17
так если у тебя хэш сохранился, но на равенство пе...

хотя вот так если логически рассуждать, вроде должен

Pavel-Павлик Автор вопроса
Tishka17
для какой цели тебе хэшируемость?

Для того, чтобы использовать в коллекциях, предоставляющих лукап за O(1). У меня одинаковые объекты имеют одинаковый хеш, но разные объекты могут иметь один хеш, так что контракт сохраняется

Pavel Павлик
Для того, чтобы использовать в коллекциях, предост...

class A: def __init__(self, x): self.data = [] self.x = x def __hash__(self): return self.x def __eq__(self, other): return self.data == other.data and self.x == other.x a1 = A(1) a2 = A(1) x = {a1: "hello"} print(x[a2]) a1.data.append(0) print(x[a2]) для меня это немного неожиданно, но наверно допустимо

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта