Методы

Методы

Имена атрибутов класса могут указывать на функции. Такие функции называются методами. Вы уже сталкивались с методами, когда работали со встроенными структурами данных. Давайте же объявим класс и метод в нём:

>>> class C:
...     def add(x, y):
...         return x + y
...
>>> C.add
<function C.add at 0x7f7bee2d1c80>
>>> C.add(4, 5)
9

Здесь C.add — обычная функция, о чём нам и говорит интерпретатор. Но сами по себе обычные функции, помещённые в класс не так интересны: те же функции мы можем группировать и в модулях. Более того, обычные функции стоит объявлять именно в модулях.

Методы же нужны для того, чтобы работать с данными объектов класса. Но для этого методы должны быть связаны (bound).

Связанные методы

Вспомните, метод list.append (list — это класс, помним и это) модифицирует именно объект списка. Посмотрим на этот метод поближе:

>>> l = []
>>> list.append(l, 42)
>>> l
[42]

Я вывал метод класса, как обычную функцию и передал первым аргументом объект списка. Метод изменил переданный список. Но ведь раньше мы вызывали этот метод в виде l.append(42)! Так вот l.append это связанная версия метода list.append: метод связан с конкретным объектом списка и знает, что именно его он должен модифицировать!

Определим класс с атрибутом и методом, затем получим экземпляр класса и посмотрим на вывод REPL для разных версий метода (связанной и не связанной):

>>> class Foo:
...     def bar():
...         pass
...
>>> x = Foo()
>>> x
<__main__.Foo object at 0x7f7beca78668>
>>> Foo.bar
<function Foo.bar at 0x7f7bee2d1d08>
>>> x.bar
<bound method Foo.bar of <__main__.Foo object at 0x7f7beca78668>>

Foo.bar — это не связанный метод, то есть обычная функция. А вот x.bar уже связан ("bound") с объектом x: обратите внимание на одну и ту же строку "<__main__.Foo object at 0x7f7beca78668>" — так Python отображает объект x.

Но как метод получает доступ к связанному объекту, спросите вы. В Python методы получают ссылку на связанный объект в качестве первого аргумента. А называть этот аргумент принято именем "self". Вот пример метода, использующего данные объекта:

>>> class Person:
...     name = 'Noname'
...     def greet(self):
...         print('Hello, ' + self.name + '!')
...
>>> bob = Person()
>>> bob.name = 'Bob'
>>> bob.greet()
Hello, Bob!
>>>
>>> alice = Person()
>>> alice.greet()
Hello, Noname!

Именно через аргумент self метод получает доступ к атрибутам связанного объекта (и его класса, конечно же).

Мы учим программированию с нуля до стажировки и работы. Попробуйте наш бесплатный курс «Введение в программирование» или полные программы обучения по Javascript, PHP, Python и Java.

Хекслет

Подробнее о том, почему наше обучение работает →