Да, в Python подкласс может иметь двух и более суперклассов — это называется множественное наследование.
Пример:
Здесь Duck — подкласс, который наследует и Flyer, и Swimmer.
Python использует алгоритм MRO (Method Resolution Order), чтобы определить порядок, в котором ищутся методы при множественном наследовании.
Потенциальные сложности:
• Если оба родителя имеют методы с одинаковыми именами, нужно понимать в каком порядке они вызываются.
• Иногда нужно явно использовать super(), особенно в ромбовидном наследовании, чтобы избежать дублирования.
Пример:
class Flyer:
def fly(self):
print(«Я могу летать»)
class Swimmer:
def swim(self):
print(«Я могу плавать»)
class Duck(Flyer, Swimmer):
pass
d = Duck()
d.fly() # Я могу летать
d.swim() # Я могу плавать
Здесь Duck — подкласс, который наследует и Flyer, и Swimmer.
Python использует алгоритм MRO (Method Resolution Order), чтобы определить порядок, в котором ищутся методы при множественном наследовании.
Потенциальные сложности:
• Если оба родителя имеют методы с одинаковыми именами, нужно понимать в каком порядке они вызываются.
• Иногда нужно явно использовать super(), особенно в ромбовидном наследовании, чтобы избежать дублирования.
👍4😱3
👍4👎1🤬1
Атрибуты, присоединенные к экземплярам, сохраняются только для этих одиночных экземпляров, но атрибуты, присоединенные к классам, разделяются всеми их подклассами и экземплярами.
👍1
👍3🔥1🤯1
Атрибут
Когда в коде пишется
category
в классе C1
создаётся внутри метода (__init__
), а значит, он становится атрибутом экземпляра, а не атрибутом класса. Такой атрибут доступен только после создания объекта через C3()
, и обращаться к нему нужно через сам объект (obj.category
), а не через класс (C3.category
).Когда в коде пишется
print(C3.category)
, Python пытается найти атрибут класса с именем category
у C3 или его родителей. Но такого атрибута нет — category создаётся только при вызове конструктора (__init__
). Поэтому попытка обращения к C3.category
приводит к ошибке AttributeError
.👍3🤯2😁1🤔1🙏1
🔍 Что происходит, когда метод класса в Python выполняет присваивание значения с использованием self, например self.attr = 10?
Anonymous Quiz
10%
Атрибут attr создается как переменная внутри метода и удаляется после его выполнения
16%
Атрибут attr создается в классе, от которого был вызван метод
70%
Атрибут attr создается или обновляется в текущем экземпляре, на котором вызван метод
4%
Атрибут attr создается в самом верхнем родительском классе
👍4🤬1
Когда в методе используется
Таким образом, присваивание через
self.attr = ...
, Python создает (или обновляет) атрибут у конкретного экземпляра, на котором был вызван метод. Это происходит динамически — никаких предварительных объявлений атрибутов в Python не требуется. Экземпляр хранит свои собственные данные, и self всегда ссылается именно на него.Таким образом, присваивание через
self
не влияет на атрибуты класса, если такие были, и не затрагивает другие экземпляры. Это ключевое отличие между атрибутами класса и экземпляра: одни общие для всех объектов, другие — индивидуальны.👍1👎1
🔍 Что выведет код?
Anonymous Quiz
13%
class-level
16%
instance-level
55%
modified-instance
15%
Error
👍4👎1
В приведённой задаче у класса MyClass есть атрибут attr на уровне класса, но при создании экземпляра (obj = MyClass()) в конструкторе init создаётся атрибут экземпляра с тем же именем — self.attr = "instance-level". Это значит, что у obj теперь есть собственный атрибут attr, который перекрывает одноимённый атрибут класса. Затем мы ещё раз меняем значение этого атрибута напрямую: obj.attr = "modified-instance" — и именно это значение теперь хранится в объекте.
👍3👏1
Какой из следующих методов НЕ является методом перегрузки операций в Python?
Anonymous Quiz
8%
__add__
8%
__sub__
14%
__mul__
71%
__combine__
👍1👎1
Методы
__add__
, __sub__
и __mul__
являются магическими методами Python, используемыми для перегрузки операторов сложения (+), вычитания (-) и умножения (*) соответственно. Метод __combine__
не является стандартным магическим методом в Python и не используется для перегрузки операторов.👏2👎1
😱2👎1
В
— Если мы передаем итерируемый объект без явного индекса (как список или кортеж), pandas создаёт индекс сам — по порядку элементов;
— Но для этого pandas должен полагаться на порядок элементов.
Множество
pandas.Series()
можно передавать различные итерируемые объекты, включая списки, кортежи, массивы NumPy и словари. Но:— Если мы передаем итерируемый объект без явного индекса (как список или кортеж), pandas создаёт индекс сам — по порядку элементов;
— Но для этого pandas должен полагаться на порядок элементов.
Множество
my_set
— неупорядоченная структура. То есть Python не гарантирует порядок элементов внутри множества, даже если при создании кажется, что порядок есть.В каком порядке интерпретатор ищет атрибут по цепочке классов и объектов?
Anonymous Quiz
28%
Суперкласс(-ы) → Класс → Экземпляр
67%
Экземпляр → Класс → Суперкласс(-ы)
1%
Порядок зависит от выделенной памяти
4%
Одновременно в экземпляре, классе и суперклассе(-ах)
🤡2👍1
Интерпретатор Python ищет атрибуты в порядке Экземпляр → Класс → Суперклассы, потому что это отражает модель наследования и переопределения в объектно-ориентированном программировании.
👍2🌭1
🌱 Как по умолчанию называется первый аргумент функции?
Anonymous Quiz
17%
args
13%
__init__
30%
self
40%
У него нет унифицированного названия
👎32💩5