Personalizando funcionalidades via herança

Programação orientada a objetos em Python

Alex Yarosh

Content Quality Analyst @ DataCamp

uma hierarquia de classes de conta

Programação orientada a objetos em Python

O que temos até agora

class BankAccount:
    def __init__(self, balance):
       self.balance = balance

    def withdraw(self, amount):
       self.balance -=amount

# Classe vazia herdada de BankAccount
class SavingsAccount(BankAccount):
    pass
Programação orientada a objetos em Python

Personalizando construtores

class SavingsAccount(BankAccount):    

    # Construtor específico para SavingsAccount com um parâmetro adicional
    def __init__(self, balance, interest_rate):  

# Chame o construtor pai usando ClassName.__init__() BankAccount.__init__(self, balance) # <--- self é um SavingsAccount mas também um BankAccount
# Adicione mais funcionalidades self.interest_rate = interest_rate
  • Pode rodar o construtor da classe pai primeiro com Parent.__init__(self, args...)
  • Adicione mais funcionalidades
  • Não precisa chamar os construtores pai
Programação orientada a objetos em Python

Crie objetos com um construtor personalizado

# Construa o objeto usando o novo construtor
acct = SavingsAccount(1000, 0.03)
acct.interest_rate
0.03
Programação orientada a objetos em Python

Adicionando funcionalidades

  • Adicione métodos como de costume
  • Pode usar dados tanto da classe pai quanto da filha
class SavingsAccount(BankAccount):    

  def __init__(self, balance, interest_rate): 
     BankAccount.__init__(self, balance) 
     self.interest_rate = interest_rate

  # Nova funcionalidade
  def compute_interest(self, n_periods = 1):
     return self.balance * ( (1 + self.interest_rate) ** n_periods - 1)

Programação orientada a objetos em Python

uma hierarquia de classes de conta

Programação orientada a objetos em Python

Personalizando funcionalidades

class CheckingAccount(BankAccount):

def __init__(self, balance, limit): BankAccount.__init__(self, balance) self.limit = limit
def deposit(self, amount): self.balance += amount
def withdraw(self, amount, fee=0):
if fee <= self.limit: BankAccount.withdraw(self, amount + fee) else: BankAccount.withdraw(self, amount + self.limit)
  • Pode mudar a assinatura (adicionar parâmetros)
  • Use Parent.method(self, args...) para chamar um método da classe pai
Programação orientada a objetos em Python
check_acct = CheckingAccount(1000, 25)

# Vai chamar withdraw de CheckingAccount
check_acct.withdraw(200)
# Vai chamar withdraw de CheckingAccount
check_acct.withdraw(200, fee=15)
bank_acct = BankAccount(1000)

# Vai chamar withdraw de BankAccount
bank_acct.withdraw(200)
# Vai gerar um erro
bank_acct.withdraw(200, fee=15)
TypeError: withdraw() recebeu um argumento
 inesperado 'fee'
Programação orientada a objetos em Python

Vamos praticar!

Programação orientada a objetos em Python

Preparing Video For Download...