4055
Комментарий:
|
4449
|
Удаления помечены так. | Добавления помечены так. |
Строка 62: | Строка 62: |
* `isinstance()` | |
Строка 92: | Строка 93: |
Долги: `__iter__`, `__del__`, `hasattr()/getattr()` |
|
Строка 94: | Строка 97: |
* В частности, прочесть про: * [[py3ref:datamodel.html#object.__del__]] * [[py3ref:datamodel.html#object.__iter__]] * [[py3ref:datamodel.html#object.__getitem__]] * [[py3ref:datamodel.html#object.__len__]] |
|
Строка 95: | Строка 103: |
1. <<EJCMC(113, DummyVec, Что-то вроде вектора)>> |
Объектная модель Python3
Долг за прошлый раз
Циклический конструктор генератора
>>> a=(i*2+1 for i in range(0,10,2) if i!=6) >>> a <generator object <genexpr> at 0x7feea8cd2938> >>> next(a) 1 >>> next(a) 5 >>> next(a) 9 >>> next(a) 17 >>> next(a) Traceback (most recent call last): File "<stdin>", line 1, in <module> StopIteration >>> def fn(seq): ... print(*seq) ... >>> fn((1,2,3)) 1 2 3 >>> fn(i*2+1 for i in range(10) if i!=6) 1 3 5 7 9 11 15 17 19
При передаче такого генератора в качестве единственного параметра функции скобки можно убрать.
Параметрические декораторы
Статья на Хабре (это продолжение, можно почитать и предыдущие две)
Объектная модель Python3
Основная статья: первый скетч про классы
- Классы как пространства имён
- Классы как конструкторы объектов
Класс — callable()
- Поля класса и поля объектов, правила видимости
- Метод как функция в классе, видимая «сквозь» объект:
- Дополнительный первый параметр
- Обязательное использование имени объекта (точнее, связи с объектом) при обращении к его полю
__init__(), когда вызывается
- Заполнение полей объекта
Параметры __init__() и их передача
__del__(), когда вызывается (почитать тут)
isinstance()
Перегрузка операций
Базовая статья: datamodel.html
Достаточно в классе определить соответствующие методы, и начинают работать len(), str() (и т. п.), а также всевозможные операции над экземплярами этого класса
__str__() и __repr()__
- Арифметические операции
- Протокол арифметической операции с учётом «правой» версии:
a+b → a.__add__(b)
Если возвращает специальный объект NotImplemented, но есть b.__radd__(), попробовать b.__radd__(a):
>>> s, n = "QWE", 8 >>> type(s), type(n) (<class 'str'>, <class 'int'>) >>> s*n 'QWEQWEQWEQWEQWEQWEQWEQWE' >>> s.__mul__(n) 'QWEQWEQWEQWEQWEQWEQWEQWE' >>> n*s 'QWEQWEQWEQWEQWEQWEQWEQWE' >>> n.__mul__(s) NotImplemented >>> s.__rmul__(n) 'QWEQWEQWEQWEQWEQWEQWEQWE'
Прочие операции (сравнения, сдвиги, @ и т. д.)
Правые версии, версии для += и ему подобных
__getitem__(), __len___(), __iter__()
- …
Долги: __iter__, __del__, hasattr()/getattr()
Д/З
Прочитать про классы в tutorial; про «волшебные методы» например, тут
- В частности, прочесть про:
EJudge: SelfCount 'Сколько экземпляров?'
Написать класс we, содержащий поле count, в котором хранится информация о количестве существующих экземпляров этого класса.
a = we() print(a.count) b, c = we(), we(), print(a.count, b.count, c.count) del b print(a.count)
1 3 3 3 2
EJudge: DummyVec 'Что-то вроде вектора'
Написать класс vector, представляющий нечто, похожее на вектор. Должна поддерживаться операция вывода в формате, представленном в примере, конструирование из произвольной числовой последовательности ненулевой длины, а также сложение с числовой последовательностью такой же длины (в том числе с другим vector)
a, b = vector([2,1,2,1,2,1,2,1]), vector(range(8)) print(a, b, a+b, b+range(8), range(8)+b)
a, b = vector([2,1,2,1,2,1,2,1]), vector(range(8)) print(a, b, a+b, b+range(8), range(8)+b)
2:1:2:1:2:1:2:1 0:1:2:3:4:5:6:7 2:2:4:4:6:6:8:8 0:2:4:6:8:10:12:14 0:2:4:6:8:10:12:14
TODO