Скажем, мы хотим предоставить абстракцию «счета» в банке. Вот один из подходов, использующий function
объект в Python:
def account():
"""Return a dispatch dictionary representing a bank account.
>>> a = account()
>>> a['deposit'](100)
100
>>> a['withdraw'](90)
10
>>> a['withdraw'](90)
'Insufficient funds'
>>> a['balance']
10
"""
def withdraw(amount):
if amount > dispatch['balance']:
return 'Insufficient funds'
dispatch['balance'] -= amount
return dispatch['balance']
def deposit(amount):
dispatch['balance'] += amount
return dispatch['balance']
dispatch = {'balance': 0,
'withdraw': withdraw,
'deposit': deposit}
return dispatch
Вот еще один подход, использующий абстракцию типов (т. class
Е. Ключевое слово в Python):
class Account(object):
"""A bank account has a balance and an account holder.
>>> a = Account('John')
>>> a.deposit(100)
100
>>> a.withdraw(90)
10
>>> a.withdraw(90)
'Insufficient funds'
>>> a.balance
10
"""
def __init__(self, account_holder):
self.balance = 0
self.holder = account_holder
def deposit(self, amount):
"""Add amount to balance."""
self.balance = self.balance + amount
return self.balance
def withdraw(self, amount):
"""Subtract amount from balance if funds are available."""
if amount > self.balance:
return 'Insufficient funds'
self.balance = self.balance - amount
return self.balance
Мой учитель начал тему «Объектно-ориентированное программирование», введя class
ключевое слово и показав нам следующие пункты:
Объектно-ориентированного программирования
Способ организации модульных программ:
- Абстракционные барьеры
- Передача сообщений
- Объединение информации и связанного поведения
Как вы думаете, первого подхода будет достаточно для удовлетворения приведенного выше определения? Если да, зачем нам class
ключевое слово для объектно-ориентированного программирования?
foo.bar()
обычно идентичен foo['bar']()
, и в редких случаях последний синтаксис действительно полезен.
object['method'](args)
, объекты Python фактически эквивалентны object['method'](object, args)
. Это становится актуальным, когда базовый класс вызывает методы в дочернем классе, например, в шаблоне стратегии.
class
выполняет аналогичную оптимизацию).