зависит от класса. Для пользовательских классов по дефолту - просто от адреса в памяти, но ты можешь сам переопределить. Для встроенных коллекций - от содержимого
я рискну вставить свое мнение. разве можно хешировать адрес памяти? быть может хешируют именно ссылку? как никак не заменяемый тип
Ну объект где-то лежит. Ты не можешь его просто передвинуть не сломав ссылки на него.
Ссылка и адрес в памяти это по твоему разные вещи?)
шта. тогда все объекты immutable
immutable An object with a fixed value это из доки, там про проперти вообще речи не идет
value - это что?
Почему? Список может менять своё место в памяти, т.к. является динамическим массивом по-сути
value of hash, наверное
immutable An object with a fixed value. Immutable objects include numbers, strings and tuples. Such an object cannot be altered. A new object has to be created if a different value has to be stored. They play an important role in places where a constant hash value is needed, for example as a key in a dictionary.
А я говорю является
in places where a constant hash value is needed
массив ссылок же
#ifndef Py_LIMITED_API typedef struct { PyObject_VAR_HEAD /* Vector of pointers to list elements. list[0] is ob_item[0], etc. */ PyObject **ob_item; /* ob_item contains space for 'allocated' elements. The number * currently in use is ob_size. * Invariants: * 0 <= ob_size <= allocated * len(list) == ob_size * ob_item == NULL implies ob_size == allocated == 0 * list.sort() temporarily sets allocated to -1 to detect mutations. * * Items must normally not be NULL, except during construction when * the list is not yet visible outside the function that builds it. */ Py_ssize_t allocated; } PyListObject; #endif я конечно в си не силен, но разве нет?
нет, меняется место где лежит содержимое списка, а не сам объект
Обсуждают сегодня