Considere o método a seguir que imprime o saldo de uma conta cadastrada com o número num. Se nenhuma conta for cadastrada com este número no banco responsável pela execução do método, imprime-se uma mensagem de erro:
void print_saldo(long num) { Conta c; c = procura(num); if (c == null) System.out.println("A conta " + num + " nao existe!"); else c.print_saldo(); }De fato, a expressão procura(num) é uma abreviação para
this.procura(num)onde this denota o próprio objeto (banco) executando o método print_saldo e que, portanto, irá executar o método procura também. Assim, a expressão acima denota o envio de uma mensagem de um objeto para ele mesmo; isto é, o banco que executa a operação print_saldo requisita a ele mesmo a conta de número num cadastrada no próprio banco.
Similarmente, temos a operação que debita uma conta específica cadastrada em um banco, caso ela exista:
void debito(long num, double val) { Conta c; c = this.procura(num); if (c == null) System.out.println("A conta " + num + " nao existe!"); else c.debito(val); }Note que os dois métodos apresentados acima têm o mesmo nome de métodos definidos na classe Conta. De fato, métodos podem ter o mesmo nome desde que tenham tipos diferentes; isto é, os métodos devem ser associados a classes diferentes ou terem o número, a ordem ou os tipos dos parâmetros diferentes. Por exemplo, a definição do método
void print_saldo() { int i; for (i = 0; i < indice; i = i + 1) { contas[i].print_saldo(); } }não causa nenhum conflito ou erro, mesmo tendo um método declarado da mesma forma em Conta. Por isso dizemos que Java suporta overloading de métodos.
Paulo Borba (phmb@di.ufpe.br) |