1 / 18

Conceitos de Orientação a Objetos

Conceitos de Orientação a Objetos. Polimorfismo Acoplamento dinâmico Classes Abstratas X Classes Concretas. Polimorfismo. Polimorfismo significa que variáveis podem referenciar mais do que um tipo.

Télécharger la présentation

Conceitos de Orientação a Objetos

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Conceitos de Orientação a Objetos • Polimorfismo • Acoplamento dinâmico • Classes Abstratas X Classes Concretas

  2. Polimorfismo • Polimorfismo significa que variáveis podem referenciar mais do que um tipo. • Funções são polimórficas quando seus operandos(parâmetros atuais) podem ter mais do que um tipo. • Tipos são polimórficos se suas operações podem ser aplicadas a operandos de mais de um tipo.

  3. Polimorfismo • A função definida por: • comprimento :: [A] -> NUM, para todos tipos de A • Informa que: • O parâmetro de entrada é uma lista. • O tipo do conteúdo da lista (A) não importa. • A função devolve um inteiro como saída. • Em linguagens com tipos monomórficos tem-se que definir diversas funções(inteiros, reais,etc.)

  4. Polimorfismo • Em OO, polimorfismo significa que diferentes tipos de objetos podem responder a uma mesma mensagem de maneiras diferentes. • Pode-se definir um método imprime() em diversas classes diferentes. • Cada versão de imprime() é adaptada para cada tipo de objeto diferente que será impresso.

  5. Polimorfismo Tipos diferentes de objetos Implementações diferentes Imprime os dados do cheque um cheque Mesma mensagem um relatório Imprime relatório imprime() uma fotografia Imprime fotografia

  6. Formas de polimorfismo Polimorfismo Ad Hoc Universal Paramétrico Coerção Inclusão Sobrecarga

  7. Coerção • Proporciona um meio de contornar a rigidez de tipos monomórficos. • Se um particular contexto demanda um determinado tipo e um tipo diferente é passado, então a linguagem verifica se há uma coerção adequada. • Um inteiro pode ser coargido para um real.

  8. Sobrecarga • Poliformismo de sobrecarga permite que um nome de função seja usado mais do que uma vez com diferentes tipos de parâmetros. • Uma função soma pode ser sobrecarregada para operar com parâmetros de tipos diferentes. • A informação sobre os tipos dos parâmetros é usada para selecionar a função apropriada.

  9. Polimorfismo paramétrico • Uma única função é codificada, e ela trabalhará uniformemente num intervalo de tipos. • Funções paramétricas são também chamadas de funções genéricas. • Considere uma classe Pilha(T), onde T é o tipo do elemento que será manipulado. • Uma classe genérica pode ser escrita independentemente do tipo dos itens armazenados.

  10. Polimorfismo de inclusão • Subtipo é uma instância de polimorfismo de inclusão, significando que elementos de um subconjunto também pertencem ao superconjunto. • Todo o objeto de um subtipo pode ser usado no contexto do supertipo. • Exemplo da hierarquia de mamíferos.

  11. Acoplamento dinâmico • Acoplamento é uma associação possivelmente entre um atributo e uma entidade. • Variáveis de programa são entidades com atributos de nome, tipo e área de armazenamento. • Tempo de acoplamento é o tempo em que ocorre o acoplamento entre a entidade e seus atributos.

  12. Acoplamento dinâmico • Acoplamento estático ocorre antes do tempo de execução, e permanece inalterado durante a execução do programa. • Acoplamento dinâmico ocorre durante o tempo de execução, e muda no curso da execução do programa. • No acoplamento dinâmico, as associações podem ser alteradas em tempo de execução.

  13. Acoplamento dinâmico • Em POO, acoplamento está relacionado com o mapeamento entre o nome de um método e sua implementação. • Uma mensagem enviada em tempo de execução é dinamicamente acoplada a uma implementação dependendo do tipo do objeto recebedor da mensagem. • Método calculaBonus() para classe Empregado e classe Diretor.

  14. Classes Abstratas X Classes Concretas • Uma classe abstrata é uma classe que não tem instâncias diretas. • Uma classe concreta é uma classe que pode ser instanciada. • Uma operação abstrata define a forma de uma operação para qual cada subclasse deve providenciar sua própria implementação.

  15. Classes Abstratas X Classes Concretas Bomba ativa( ) BombaDiesel BombaD’Água ativa( ) ativa( )

  16. Classes Abstratas X Classes Concretas • Duas idéias principais envolvidas com a noção de classe abstrata: • Presença de operações abstratas e • Habilidade de criar instâncias • A presença de uma operação abstrata implica na inabilidade de instanciar objetos. • Uma classe pode ser abstrata e não conter operações abstratas.

  17. Exemplo Cão mostraRaça( ) Boxer Cocker Schnauzer mostraRaça( ) mostraRaça( ) mostraRaça( )

  18. Exemplo abstract class Cao{ void mostraRaca( ){ System.out.println(“Raca não definida”); } class Schauzer extends Cao{ void mostraRaca( ){ System.out.println(“Raca Schnauzer”); } }

More Related