Paradigmas da Programação PPROG. Linguagem JAVA. Interfaces. (Livro Big Java, Late Objects Capítulo 9) Nelson Freire (ISEP DEI-PPROG 2013/14) 1/33
|
|
|
- Therezinha Lemos Escobar
- 10 Há anos
- Visualizações:
Transcrição
1 PPROG Paradigmas da Programação Linguagem JAVA Interfaces (Livro Big Java, Late Objects Capítulo 9) Nelson Freire (ISEP DEI-PPROG 2013/14) 1/33
2 PPROG Motivação para usar Interfaces Definição de Interface Interface define Tipo de Dados Estruturas de Interfaces Hierarquia de Interfaces Herança Múltipla Declaração de uma Interface Uso de Interfaces Implementação numa classe Declaração Variável Parâmetro de Método Comparação Interfaces Classes Abstratas Sumário Geral Interfaces Java Nativas Exemplos Comparable Comparator Interesse de Comparable e Comparator Ordenação e Pesquisa de Contentores Ordenação de Contentores Métodos de Ordenação das Classes Arrays Collections Ordenação de Arrays Com Objetos Comparable Com Objetos não-comparable Ordenação de ArrayLists Com Objetos Comparable Com Objetos não-comparable Comparação de Interfaces Comparable Comparator Nelson Freire (ISEP DEI-PPROG 2013/14) 2/33
3 Aplicação Processa instâncias da hierarquia de classes Motivação para usar Interfaces 1/6 A B1 C1 B2 C2 Guarda todas as instâncias num contentor Nelson Freire (ISEP DEI-PPROG 2013/14) 3/33
4 Problema 1 Motivação para usar Interfaces 2/6 Executar m1() das instâncias do contentor Através de varrimento completo do contentor Solução A B1 C1 B2 C2 Tipo Compatível com todos tipos da hierarquia e que possua m1() Nelson Freire (ISEP DEI-PPROG 2013/14) 4/33
5 Problema 2 Executar m2() das instâncias Cx (x:1,2) do contentor Solução Através de varrimento completo do contentor Motivação para usar Interfaces 3/6 B1 A B2 C1 público m2() C2 público m2()?? Tipo Compatível com tipos Cx e que possua m2() Nelson Freire (ISEP DEI-PPROG 2013/14) 5/33
6 Solução Motivação para usar Interfaces 4/6?? Preciso tipo de dados Tipo de todas as instâncias Cx // uma instância pode ser de vários tipos // ex: C1 é também do tipo B1 e A Declare método m2 // garante m2() em todas as classes Cx Tipo A não serve Tipo comum.mas não declara método m2 // método não-comum a todos obj. da hier. Preciso novo tipo de dados Exemplo: Calculos Nelson Freire (ISEP DEI-PPROG 2013/14) 6/33
7 Solução Motivação para usar Interfaces 5/6 B1 A B2 Calculos público m2() C1 público m2() C2 público m2() Em Java, novo tipo Calculos Não pode ser definido por classe Permitida apenas herança de classes simples Subclasse só tem uma superclasse direta T E F G Tem de ser definido por Interface Java Alternativa à herança múltipla H I J Herança Simples Nelson Freire (ISEP DEI-PPROG 2013/14) 7/33
8 Motivação Geral para usar Interfaces Motivação para usar Interfaces 6/6 Necessidade de garantir que múltiplas classes, não relacionadas hierarquicamente (mesmo ramo), sejam também de um mesmo tipo de dados de modo a assegurar que possuam métodos comuns (interface comum). Interface X métodos Especifica tipo de dados X é-um Object implementa K M Classe L também é do tipo X L métodos N O P métodos Classe P também é do tipo X Hierarquia de Classes Alternativa Java à Herança de Classes múltipla Nelson Freire (ISEP DEI-PPROG 2013/14) 8/33
9 Definição de Interface Interface é Uma especificação de um tipo de dados abstrato (sem implementação dos métodos) que qualquer classe pode implementar (classe em qualquer ponto da Hierarquia de Classes Java) Especificação pode definir Conjunto de métodos de instância abstratos (só cabeçalhos) // opcional Conjunto de constantes // opcional Interface Y constantes Tipo Y métodos é-um Object implementa K M L métodos N O P métodos Também é do Tipo Y Hierarquia de Classes Nelson Freire (ISEP DEI-PPROG 2013/14) 9/33
10 Interface Especifica Tipo de dados referência Tipos de Dados Java Primitivos Referência Classes Interfaces Interface define Tipo de Dados Interface Y constantes métodos Tipo Y (tipo Referência) é-um K Object implementa M L métodos N O Hierarquia de Classes P métodos Nelson Freire (ISEP DEI-PPROG 2013/14) 10/33
11 Especificações Opcionais Estruturas de Interfaces Métodos Constantes Estruturas de Interfaces possíveis Interface Interface Interface Interface constantes constantes métodos métodos Nelson Freire (ISEP DEI-PPROG 2013/14) 11/33
12 Hierarquia de Interfaces Interfaces podem pertencer a Hierarquias de Interfaces Diferente da Hierarquia de Classes X Superinterface Tipos de Hierarquia (em Java) é-um Hierarquia de Classes Y W Subinterface Hierarquia de Interfaces Z V U Hierarquia de Interfaces Estabelece relações hierárquicas entre interfaces Relações do tipo é-um Subinterface estende (aumenta) Superinterface public interface V extends Y, W { Permitida herança múltipla Subinterface pode herdar múltiplas Superinterfaces diretas Uma interface pode ter ou não Superinterfaces Exemplos Interface X // não tem Superinterface Interface Z // tem Superinterfaces Y e X Nelson Freire (ISEP DEI-PPROG 2013/14) 12/33
13 Declaração de uma Interface Sintaxe [modificador de acesso] interface nomeinterface [ extends Interface1,, InterfaceN ] { // Declarações de constantes [public static final] tipo nomeconstante1 = value1; Constantes Por omissão (implicitamente) public static final [public static final] tipo nomeconstanten = valuen; // Declarações de métodos (só cabeçalhos) [public abstract] tiporetorno nomemetodo1( listaparâmetros ); [public abstract] tiporetorno nomemetodom( listaparâmetros ); Métodos Por omissão public abstract Só de instância Exemplos Definido pelo utilizador (programador) public interface Calculos { double m2(); Nativas do Java public interface Serializable { Uma interface é armazenada num ficheiro com o mesmo nome e extensão java Exemplo: Calculos.java // abordada em Ficheiros public interface Comparable { int compareto( Object o ); Nelson Freire (ISEP DEI-PPROG 2013/14) 13/33
14 Interfaces podem ser usadas para Uso de Interfaces 1/5 Implementar numa classe Declarar Variável Parâmetro de método Nelson Freire (ISEP DEI-PPROG 2013/14) 14/33
15 Implementação de uma interface numa classe Depende do tipo de classe Abstrata: não é obrigatório implementar qualquer método da interface usada Concreta: se não implementar todos os métodos da interface usada, tem de passar a classe abstrata Declaração de classe concreta que implementa (usa) interfaces [modificador de acesso] class nome [extends Classe] implements Interface1,, InterfaceN { // implementação obrigatória de todos os métodos dos N interfaces Declaração de classe abstrata que implementa (usa) interfaces Exemplo [modif. de acesso] abstract class nome [extends Classe] implements Interface1,, InterfaceN { // implementação dos métodos dos N interfaces não é obrigatória Próximo slide Uso de Interfaces 2/5 Nelson Freire (ISEP DEI-PPROG 2013/14) 15/33
16 Exemplo de implementação da interface Calculos Uso de Interfaces 3/5 public class C1 extends B1 implements Calculos { public double m2() { public class C2 extends B2 implements Calculos { public double m2() { B1 C1 público m2() A Hierarquia de Classes B2 C2 público m2() Calculos público m2() implementa Classes C1 e C2 implementam método especificado no tipo Calculos Nelson Freire (ISEP DEI-PPROG 2013/14) 16/33
17 Na declaração de variáveis de tipo Interface Uso de Interfaces 4/5 Sintaxe nomeinterface nomevariável; nomeinterface[ ] nomevariável; // variável tipo simples // variável tipo array Exemplo Calculos x1; // variável tipo simples x1 = new C1(); Calculos x2 = new C2(); Calculos[] a = new Calculos[10]; a[0] = x1; a[1] = x2; // variável tipo array Nelson Freire (ISEP DEI-PPROG 2013/14) 17/33
18 Na declaração de parâmetros de métodos Uso de Interfaces 5/5 Sintaxe nomeinterface nomeparâmetro; nomeinterface[ ] nomeparâmetro; // parâmetro tipo simples // parâmetro tipo array Exemplo public void m( Calculos c ){ // Corpo do método // parâmetro tipo simples public static void ordenar( Calculos[ ] a ){ // Corpo do método // parâmetro tipo array Nelson Freire (ISEP DEI-PPROG 2013/14) 18/33
19 Têm propósitos diferentes Classes abstratas: Permitir criação de hierarquias de classes Interfaces: Especificar e garantir implementação de funcionalidades adicionais comuns a classes não relacionadas hierarquicamente Há muitas diferenças entre interfaces e classes abstratas Exemplos Comparação entre Interfaces e Classes Abstratas 100% abstrato (abstração total) Interface Classe pode implementar vários interfaces Classe Abstrata Pode não ser 100% abstrato (abstração parcial ou total) Classe só pode herdar uma classe abstrata Daí Interfaces não podem ser considerados substitutos de classes abstratas Não há regras para decidir entre classes abstratas e interface Algumas orientações: Classe abstrata não é apropriada para definir métodos que não são comuns a todas as subclasses duma hierarquia de classes Porque obriga implementação dos seus métodos abstratos nas classes instanciáveis Usar interfaces para evitar criação de hierarquias de classes artificiais e a reestruturação de hierarquias Nelson Freire (ISEP DEI-PPROG 2013/14) 19/33
20 PPROG Motivação para usar Interfaces Definição de Interface Interface define Tipo de Dados Estruturas de Interfaces Hierarquia de Interfaces Herança Múltipla Declaração de uma Interface Uso de Interfaces Implementação numa classe Declaração Variável Parâmetro de Método Comparação Interfaces Classes Abstratas Sumário Geral Interfaces Java Nativas Exemplos Comparable Comparator Interesse de Comparable e Comparator Ordenação e Pesquisa de Contentores Ordenação de Contentores Métodos de Ordenação das Classes Arrays Collections Ordenação de Arrays Com Objetos Comparable Com Objetos não-comparable Ordenação de ArrayLists Com Objetos Comparable Com Objetos não-comparable Comparação de Interfaces Comparable Comparator Nelson Freire (ISEP DEI-PPROG 2013/14) 20/33
21 Java Nativos Interfaces Interfaces Java Nativas Disponibilizados pelo JDK Exemplos Comparable Comparator Interesse de Comparable e Comparator Ordenação Pesquisa de Contentores Realizada por Métodos das Classes Nativas Arrays Collections Nesta Aula Abordada a Ordenação de Contentores Nelson Freire (ISEP DEI-PPROG 2013/14) 21/33
22 Java Nativos Métodos de Ordenação de Contentores Disponibilizados pelas Classes // package java.util Arrays // prestadora de serviços para arrays Collections // prestadora de serviços para coleções (Ex: ArrayList) Métodos de Ordenação da Classe Arrays Aplicam-se a Contentores Tipo Array Com Objetos Comparable // requer interface Comparable Com Objetos Não-Comparable // requer interface Comparator Métodos de Ordenação da Classe Collections Aplicam-se a Contentores Tipo ArrayList Com Objetos Comparable // requer interface Comparable Com Objetos Não-Comparable // requer interface Comparator Nelson Freire (ISEP DEI-PPROG 2013/14) 22/33
23 Java Nativos Métodos da Classe Arrays Para arrays com Objetos Comparable Métodos de Ordenação de Contentores Tipo Array public static void sort( Object[] a ) // método de classe Obrigatório Objetos do array a sejam do tipo Comparable Cujas classes implementam interface Comparable Podem implicar a alteração de classes existentes Ordenação ascendente Critério de ordenação definido nas classes dos objetos Para arrays com Objetos Não-Comparable public static void sort( T[] a, Comparator c ) // método de classe Objetos não-comparable Cujas classes não implementam interface Comparable Não obrigam alteração de classes existentes Ordenação ascendente Critério de ordenação definido no objeto Comparator c passado por parâmetro Nelson Freire (ISEP DEI-PPROG 2013/14) 23/33
24 Java Nativos Exemplo Ordenação de array com instâncias da Hierarquia de Classes abaixo apresentada Critério de ordenação: resultado de m1() Ordem: ascendente Para tornar Objetos Comparable Classes têm de implementar interface Comparable Critério de Ordenação Definido no método compareto() dos objetos do array Método de Ordenação Arrays.sort( array ) Ordenação de Array com Objetos Comparable import java.util.arrays; public class DemoInterfaces { public static void main(string[] args) { A[] a = new A[10]; a[0] = new B1(); a[1] = new B2(); Arrays.sort( a ); // por m1() for(int i=0; i<a.length; i++){ System.out.println( a[i] ); // objetos ordenados Interface Comparable público compareto() implementa A B1 B2 C1 C2 Hierarquia de Classes Nelson Freire (ISEP DEI-PPROG 2013/14) 24/33
25 Java Nativos Declaração Interface Comparable 1/2 public interface Comparable { public int compareto( Object obj ); Método compareto Requisitos Comparar objeto parâmetro obj com objeto recetor da mensagem Retornar valor inteiro Negativo (<0 : típico -1) // valor do recetor < valor do parâmetro Igual a Zero (0) // valor do recetor = valor do parâmetro Positivo (>0 : típico 1) // valor do recetor > valor do parâmetro Implementado por algumas classes nativas do Java Objetivo Ter uma ordem nas suas instâncias // designada ordem natural Exemplos String Date Implementação desta interface numa classe garante a quem a usa Ordem nas suas instâncias Segundo critério (método) de ordenação definido no método compareto Nelson Freire (ISEP DEI-PPROG 2013/14) 25/33
26 Java Nativos Exemplo Interface Comparable 2/2 Implements na superclasse Garante implementações em todas as classes instanciáveis da hierarquia Interface Comparable público compareto() implementa public class A implements Comparable { public int compareto( Object obj ) { A o = (A) obj; B1 C1 A B2 C2 Hierarquia de Classes if ( m1() > o.m1() ) return 1; else if (m1() < o.m1() ) return -1; else return 0; public class B1 extends A { // Herda método compareto de A public class B2 extends A { // Herda método compareto de A Nelson Freire (ISEP DEI-PPROG 2013/14) 26/33
27 Java Nativos Exemplo Anterior Método de Ordenação Arrays.sort( array, objetocomparator ) Critério de Ordenação Definido no método compare() de um objeto auxiliar do tipo Comparator (objetocomparator) Vantagens Não obriga a modificar classes dos objetos do array Permite ordenar mesmo array por critérios diferentes Exemplo import java.util.arrays; public class DemoInterfaces { public static void main(string[] args) { A[] a = new A[10]; a[0] = new B1(); a[1] = new B2(); Ordenação de Array com Objetos não-comparable Slides Seguintes Comparator criterio = new Comparator() {? ; Arrays.sort( a, criterio ); // por m1() for(int i=0; i<a.length; i++){ System.out.println(a[i]); // obj. ordenados Nelson Freire (ISEP DEI-PPROG 2013/14) 27/33 B1 C1 Interface Comparator público compare() A Hierarquia de Classes implementa Classe Auxiliar (Anónima) B2 C2
28 Java Nativos Declaração Interface Comparator 1/2 public interface Comparator { int compare( Object o1, Object o2 ); Semelhante ao interface Comparable Especifica método com Sintaxe diferente Semântica igual Método compare Requisitos Comparar os objetos parâmetro (o1 e o2) Retornar como resultado um valor inteiro Negativo (<0 : típico -1) // valor do parâmetro 1 < valor do parâmetro 2 Igual a Zero (0) // valor do parâmetro 1 = valor do parâmetro 2 Positivo (>0 : típico 1) // valor do parâmetro 1 > valor do parâmetro 2 Nelson Freire (ISEP DEI-PPROG 2013/14) 28/33
29 Java Nativos Interface Comparator 2/2 public class DemoInterface { public static void main(string[] args) { A[] a = new A[10]; a[0] = new B1(); a[1] = new B2(); // Objeto para definir critério de ordenação das instâncias Comparator criterio = new Comparator() { public int compare( Object o1, object o2 ) { ; double r1 = ( (A) o1 ).m1(); double r2 = ( (A) o2 ).m1(); if ( r1 == r2 ) return 0; else if ( r1 > r2 ) return 1; else return -1; // Ordenação do array segundo critério fornecido em criterio Arrays.sort( a, criterio ); for(int i=0; i<a.length; i++){ System.out.println( a[i] ); // Exemplo de uso da interface Comparator // classe anónima cria só 1 objeto // classe anónima = classe interna // Ordenação pelo m1() // instâncias ordenadas Nelson Freire (ISEP DEI-PPROG 2013/14) 29/33
30 Java Nativos Métodos da Classe Collections Semelhantes aos da classe Arrays // parâmetro tipo List em vez de array Para ArrayLists com Objetos Comparable Métodos de Ordenação de Contentores Tipo ArrayList public static void sort( List lista ) // método de classe Obrigatório Objetos do arraylist lista sejam do tipo Comparable Cujas classes implementam interface Comparable Podem implicar a alteração de classes existentes Ordenação ascendente Critério de ordenação definido nas classes dos objetos Para ArrayLists com Objetos Não-Comparable public static void sort( List lista, Comparator c ) // método de classe Objetos não-comparable Cujas classes não implementam interface Comparable Não obrigam alteração de classes existentes Ordenação ascendente Critério de ordenação definido no objeto Comparator c passado por parâmetro Nelson Freire (ISEP DEI-PPROG 2013/14) 30/33
31 Java Nativos Exemplo Ordenação de ArrayList com Objetos Comparable Obrigatório contentor de instâncias Comparable public class DemoInterfaces { public static void main(string[] args) { ArrayList a = new ArrayList(); a.add( new B1() ); a.add( new B2() ); Collections.sort( a ); // por m1() public class A implements Comparable { public int compareto( Object o ) { if ( m1() > ( (A) o).m1() ) return 1; else if (m1() < ( (A) o).m1() ) return -1; else return 0; for( Object obj : a ){ System.out.println( obj ); Interface Comparable público compareto() implementa A B1 B2 C1 C2 Hierarquia de Classes Nelson Freire (ISEP DEI-PPROG 2013/14) 31/33
32 Java Nativos Exemplo Ordenação de ArrayList com Objetos não-comparable public class DemoInterfaces { public static void main(string[] args) { ArrayList a = new ArrayList(); a.add( new B1() ); a.add( new B2() ); Comparator criterio = new Comparator() { public int compare(object o1, object o2) { ; double r1 = ( (A) o1 ).m1(); double r2 = ( (A) o2 ).m1() if ( r1 == r2 ) return 0; else if ( r1 > r2 ) return 1; else return -1; // Ordenação do array segundo critério fornecido em criterio Collections.sort( a, criterio ); for( Object obj : a ){ System.out.println( obj ); // classe anónima cria só 1 objeto // para definir critério de ordenação das figuras // Ordenação por m1() // mostra instâncias ordenadas Nelson Freire (ISEP DEI-PPROG 2013/14) 32/33 B1 A Hierarquia de Classes B2 Interface Comparator público compare() implementa Classe Auxiliar (Anónima)
33 Java Nativos Comparator Comparação de Interfaces: Comparable e Comparator Permite solução mais flexível do que solução Comparable Solução Comparable Obriga implementação dessa interface Em todas as classes dos objetos a ordenar Inaceitável quando se pretende código estável, genérico e incremental Ou então, numa nova subclasse Apenas para ordenar Interface Comparable implementa Classe ("a ordenar") Critério de Ordenação Permite só 1 critério de ordenação Definido nas classes dos objetos a ordenar Solução Comparator Não obriga implementação da interface nas classes dos objetos a ordenar i.e., não requer a modificação de classes existentes Permite múltiplos critérios de ordenação Classe ("a ordenar") Interface Comparator implementa Classe Auxiliar Critério de Ordenação Definidos em classes auxiliares tipo Comparator Nelson Freire (ISEP DEI-PPROG 2013/14) 33/33
Programação Orientada por Objetos
PPROG Paradigmas da Programação Programação Orientada por Objetos Relações entre Dependência Agregação Composição Associação (Livro Big Java, Late Objects Capítulo 12) Nelson Freire (ISEP DEI-PPROG 2014/15)
Capítulo 4. Packages e interfaces
Capítulo 4. Packages e interfaces 1/17 Índice Indice 4.1 - Package 4.2 - Interface 2/17 Índice 4.1 Package 4.1 - Package 4.2 -- Interface 3/17 4.1 Package Package ou pacote está para o Java como as directorias
7 RTTI e Interfaces. Desenvolvimento OO com Java. Vítor E. Silva Souza ([email protected]) http://www.inf.ufes.
Desenvolvimento OO com Java 7 RTTI e Interfaces Vítor E. Silva Souza ([email protected]) http://www.inf.ufes.br/ ~ vitorsouza Departamento de Informática Centro Tecnológico Universidade Federal do
Algoritmia e Programação APROG. Linguagem JAVA. Básico. Nelson Freire (ISEP DEI-APROG 2012/13) 1/31
APROG Algoritmia e Programação Linguagem JAVA Básico Nelson Freire (ISEP DEI-APROG 2012/13) 1/31 Linguagem Java Estrutura de um Programa Geral Básica Estruturas de Dados Variáveis Constantes Tipos de Dados
Slide 1 Deitel/Deitel, 8e. Java Como programar Copyright 2010 Pearson Education
Java Como Programar, 8/E Slide 1 Slide 2 Slide 3 Métodos genéricos e classes genéricas (e interfaces) permitem especificar, com uma única declaração de método, um conjunto de métodos relacionados ou, com
Programação OO em Java. Profa Andréa Schwertner Charão DELC/CT/UFSM
Programação OO em Java Profa Andréa Schwertner Charão DELC/CT/UFSM Sumário Classes abstratas Interfaces Tipos genéricos Coleções Classes abstratas São classes que não podem ser instanciadas, porque representam
Técnicas de Programação II
Técnicas de Programação II Aula 06 Orientação a Objetos e Classes Edirlei Soares de Lima Orientação a Objetos O ser humano se relaciona com o mundo através do conceito de objetos.
Laboratório de Programação. Aula 13 Java 5COP088. Aula 13 Genéricos e Conjuntos Java Prof. Dr. Sylvio Barbon Junior. Sylvio Barbon Jr barbon@uel.
5COP088 Laboratório de Programação Aula 13 Genéricos e Conjuntos Java Prof. Dr. Sylvio Barbon Junior 1 Sumário: 1) Métodos hashcode(), equals() e tostring(); 2) Conjuntos; 3) Genéricos; 4) Resumo. 2 1)
Programação OO em Java. Profa Andréa Schwertner Charão DELC/CT/UFSM
Programação OO em Java Profa Andréa Schwertner Charão DELC/CT/UFSM Sumário Classes abstratas Interfaces Tipos genéricos Coleções Introdução GUI Classes abstratas São classes que não podem ser instanciadas,
EXERCÍCIOS SOBRE ORIENTAÇÃO A OBJETOS
Campus Cachoeiro de Itapemirim Curso Técnico em Informática Disciplina: Análise e Projeto de Sistemas Professor: Rafael Vargas Mesquita Este exercício deve ser manuscrito e entregue na próxima aula; Valor
Módulo 07 Características Avançadas de Classes
Módulo 07 Características Avançadas de Classes Última Atualização: 15/06/2010 1 Objetivos Descrever variáveis, métodos e iniciadores static Descrever a semântica do modificador final em classes, métodos
Construção de novas Classes em Java. Classes Atributos Métodos Herança...
Construção de novas Classes em Java Classes Atributos Métodos Herança... 1 Exemplo Representação em UML Java (Unified Modeling Language) Stack items : Vector Stack( ) push( ) pop( ) isempty( ) finalize(
Análise de Programação
Análise de Programação Conceitos Avançados da Linguagem de Programação Java Prof Gilberto B Oliveira Encapsulamento Proteger o dado dentro de uma classe (capsula segura) Facilita o uso da classe por outros
Programação Orientada a Objetos. Encapsulamento
Programação Orientada a Objetos Encapsulamento de Dados Ocultação de dados Garante a transparência de utilização dos componentes do software, facilitando: Entendimento Reuso Manutenção Minimiza as interdependências
5 Caso de estudo O cartão fidelidade
5 Caso de estudo O cartão fidelidade Cartão de fidelização de clientes das distribuidoras de combustível. Definição em JAVA da classe CartaoFidelidade, que deverá apresentar uma funcionalidade semelhante
Programação de Computadores - I. Profª Beatriz Profº Israel
Programação de Computadores - I Profª Beatriz Profº Israel As 52 Palavras Reservadas O que são palavras reservadas São palavras que já existem na linguagem Java, e tem sua função já definida. NÃO podem
Comandos de repetição For (inicialização; condição de execução; incremento/decremento) { //Código }
Este documento tem o objetivo de demonstrar os comandos e sintaxes básicas da linguagem Java. 1. Alguns passos para criar programas em Java As primeiras coisas que devem ser abordadas para começar a desenvolver
Keeper of Knowledge. Capítulo 2 Classes em Java
Capítulo 2 Classes em Java INTRODUÇÃO Uma classe é um conjunto de software que representa uma realidade qualquer, que pode ser representada por números e símbolos. Uma classe possui dados de um ou mais
Paradigmas da Programação PPROG. Tipos Enumerados. Nelson Freire (ISEP DEI-PPROG 2013/14) 1/20
PPROG Paradigmas da Programação Tipos Nelson Freire (ISEP DEI-PPROG 2013/14) 1/20 Sumário Interesse Definição Implementação Declaração Valor de um Tipo Enumerado Variável de Tipo Enumerado Métodos Automáticos
Universidade da Beira Interior Cursos: Matemática /Informática e Ensino da Informática
Folha 1-1 Introdução à Linguagem de Programação JAVA 1 Usando o editor do ambiente de desenvolvimento JBUILDER pretende-se construir e executar o programa abaixo. class Primeiro { public static void main(string[]
Java 2 Standard Edition Como criar classes e objetos
Java 2 Standard Edition Como criar classes e objetos Helder da Rocha www.argonavis.com.br 1 Assuntos abordados Este módulo explora detalhes da construção de classes e objetos Construtores Implicações da
Introdução à Programação. Interface, Polimorfismo e Dynamic Binding
Introdução à Programação Interface, Polimorfismo e Dynamic Binding Interface Programador Java PLENO Possuir sólida experiência em programação Desenvolvimento na linguagem JAVA Webservice, Struts ou JSF(desejável)
Programação Orientada a Objetos em Java
Programação Orientada a Objetos em Java Rone Ilídio da Silva Universidade Federal de São João del-rei Campus Alto Paraopeba 1:14 1 Objetivo Apresentar os principais conceitos de Programção Orientada a
Programação por Objectos. Java
Programação por Objectos Java Parte 2: Classes e objectos LEEC@IST Java 1/24 Classes (1) Sintaxe Qualif* class Ident [ extends IdentC] [ implements IdentI [,IdentI]* ] { [ Atributos Métodos ]* Qualif:
Java. Marcio de Carvalho Victorino www.dominandoti.eng.br
Java Marcio de Carvalho Victorino www.dominandoti.eng.br 3. Considere as instruções Java abaixo: int cont1 = 3; int cont2 = 2; int cont3 = 1; cont1 += cont3++; cont1 -= --cont2; cont3 = cont2++; Após a
3 Classes e instanciação de objectos (em Java)
3 Classes e instanciação de objectos (em Java) Suponhamos que queremos criar uma classe que especifique a estrutura e o comportamento de objectos do tipo Contador. As instâncias da classe Contador devem
Lista de Contas: Assinatura. Lista de Contas. Listas de Contas: Descrição. Listas de Contas: Descrição. Listas de Contas: Descrição
Lista de Contas Lista de Contas: Assinatura null Quais são os métodos necessários? class ListaDeContas { void inserir (Conta c) { void retirar (Conta c) { Conta procurar (String num) { Listas de Contas:
Análise e Projeto Orientados por Objetos
Análise e Projeto Orientados por Objetos Aula 01 Orientação a Objetos Edirlei Soares de Lima Paradigmas de Programação Um paradigma de programação consiste na filosofia adotada na
Programação Orientada a Objectos - P. Prata, P. Fazendeiro. Cartão de fidelização de clientes das distribuidoras de combustível.
Caso de estudo O cartão fidelidade Cartão de fidelização de clientes das distribuidoras de combustível. Definição em JAVA da classe CartaoFidelidade, que deverá apresentar uma funcionalidade semelhante
Aula 2. Objetivos. Encapsulamento na linguagem Java; Utilizando a referência this.
Aula 2 Objetivos Encapsulamento na linguagem Java; Utilizando a referência this. Encapsulamento, data hiding é um conceito bastante importante em orientação a objetos. É utilizado para restringir o acesso
Programação por Objectos. Java
Programação por Objectos Java Parte 6: Herança e Polimorfismo LEEC@IST Java 1/52 Herança revisão A herança é um mecanismo em que a subclasse constitui uma especialização da superclasse. A superclasse pode
Encapsulamento de Dados
Encapsulamento de Dados Universidade Católica de Pernambuco Ciência da Computação Prof. Márcio Bueno [email protected] Fonte: Material da Profª Karina Oliveira Modificadores de Visibilidade Especificam
8 Classes Internas. Desenvolvimento OO com Java. Vítor E. Silva Souza ([email protected]) http://www.inf.ufes.
Desenvolvimento OO com Java 8 Classes Internas Vítor E. Silva Souza ([email protected]) http://www.inf.ufes.br/ ~ vitorsouza Departamento de Informática Centro Tecnológico Universidade Federal do
Java Básico. Classes Abstratas, Exceções e Interfaces Prof. Fernando Vanini Ic-Unicamp
Java Básico Classes Abstratas, Exceções e Interfaces Prof. Fernando Vanini Ic-Unicamp Classes Abstratas construção de uma classe abstrata construção de classes derivadas Classes e Herança Uma classe define
Programas eram lineares e com poucos módulos (Programação estruturada) Aumento da complexidade dos sistemas e difícil reusabilidade dos mesmos
OO -Objetos, classes, atributos, métodos, estado, comportamento e identidade (Slide) Prof. Bruno Gomes [email protected] Programação Orientada a Objetos Introdução Programas eram lineares e com poucos
Coleções. Page 1. Coleções. Prof. Anderson Augustinho Uniandrade
Page 1 podem ser comparadas com arrays, visto que também apresentam a capacidade de armazenar referências para vários objetos. Entretanto, as coleções apresentam uma gama de funcionalidades bem maior do
Programação Orientada a Objetos em Java. Herança
Universidade Federal do Amazonas Departamento de Ciência da Computação IEC481 Projeto de Programas Programação Orientada a Objetos em Java Herança Professor: César Melo Slides baseados em materiais preparados
Programação Orientada a Objetos (DPADF 0063)
Programação Orientada a Objetos (DPADF 0063) Aula 5 Herança Universidade Federal de Santa Maria Colégio Agrícola de Frederico Westphalen Curso Superior de Tecnologia em Sistemas para Internet Prof. Bruno
Classes Abstratas e Interfaces
Java Básico Classes Abstratas e Interfaces Marco Antonio, Arquiteto de Software TJDF [email protected] Novembro/2005 Classe abstrata Recurso avançado da OO Não pode ser instanciada Deve ser instanciada
Exercícios de Revisão Java Básico
Exercícios de Revisão Java Básico (i) Programação básica (estruturada) 1) Faça um programa para calcular o valor das seguintes expressões: S 1 = 1 1 3 2 5 3 7 99... 4 50 S 2 = 21 50 22 49 23 48...250 1
Computação II Orientação a Objetos
Computação II Orientação a Objetos Fabio Mascarenhas - 2014.1 http://www.dcc.ufrj.br/~fabiom/java Classes abstratas Até agora, usamos interfaces toda vez que queríamos representar algum conceito abstrato
Padrão Básico de Projeto: Interfaces e Polimorfismo
Padrão Básico de Projeto: Interfaces e Polimorfismo Herança de implementação versus herança de interface Há uma diferença grande entre uma classe e seu tipo A classe define ambos um tipo e uma implementação
ARRAYS. Um array é um OBJETO que referencia (aponta) mais de um objeto ou armazena mais de um dado primitivo.
Cursos: Análise, Ciência da Computação e Sistemas de Informação Programação I - Prof. Aníbal Notas de aula 8 ARRAYS Introdução Até agora, utilizamos variáveis individuais. Significa que uma variável objeto
Capítulo 3. Programação por objectos em Java
Capítulo 3. Programação por objectos em Java 1/46 Índice Indice 3.1 - Qualificadores de visualização 3.2 - Classe 3.3 - Objecto 3.4 - Métodos 3.5 - Herança 3.6 - Reescrita de métodos 3.7 - Classes abstractas
Computação II - Java Prof. Adriano Joaquim de Oliveira Cruz Aula Prática - Herança, Polimorfismo e Construtores
Computação II - Java Prof. Adriano Joaquim de Oliveira Cruz Aula Prática - Herança, Polimorfismo e Construtores 1 Exercícios Exercício 1: Construtores e Testes Analise a classe Conta.java, mostrada na
Programação Orientada a Objetos em java. Polimorfismo
Programação Orientada a Objetos em java Polimorfismo Polimorfismo Uma característica muito importante em sistemas orientados a objetos Termo proveniente do grego, e significa muitas formas Em POO, significa
Linguagem de Programação JAVA. Técnico em Informática Professora Michelle Nery
Linguagem de Programação JAVA Técnico em Informática Professora Michelle Nery Agenda Regras paravariáveis Identificadores Válidos Convenção de Nomenclatura Palavras-chaves em Java Tipos de Variáveis em
BSI UFRPE Prof. Gustavo Callou [email protected]
BSI UFRPE Prof. Gustavo Callou [email protected] Coleções List Set Map Classes e interfaces do pacote java.util que representam listas, conjuntos e mapas. Solução flexível para armazenar objetos. Quantidade
Módulo 06 Desenho de Classes
Módulo 06 Desenho de Classes Última Atualização: 13/06/2010 1 Objetivos Definir os conceitos de herança, polimorfismo, sobrecarga (overloading), sobreescrita(overriding) e invocação virtual de métodos.
Curso Adonai QUESTÕES Disciplina Linguagem JAVA
1) Qual será o valor da string c, caso o programa rode com a seguinte linha de comando? > java Teste um dois tres public class Teste { public static void main(string[] args) { String a = args[0]; String
Orientação a Objetos com Java
Orientação a Objetos com Java Julio Cesar Nardi [email protected] 2011/2 Apresentação 3: Orientação Objetos: Conceitos Básicos Objetivos: Compreender os Conceitos Básicos da Orientação a Objetos;
Java TM e o Modelo de Objetos
Java TM e o Modelo de Objetos Java Deployment Course: Aula 1 por Jorge H C Fernandes ([email protected]) DIMAp-UFRN Java e o Modelo de Objetos Objetivos desta Aula Introduzir conceitos básicos do modelo
Material de Apoio 5. int getres() { return res; O que estas classes possuem em comum? 1) 2) 3)
pg. 1/6 Material de Apoio 5 Herança Observe o código das classes Fatorial e Fibonacci apresentados abaixo. class Fatorial { class Fibonacci { private int n, res; private int n, res; public Fatorial( int
BSI UFRPE Prof. Gustavo Callou [email protected]
BSI UFRPE Prof. Gustavo Callou [email protected] HelloWorld.java: public class HelloWorld { public static void main (String[] args) { System.out.println( Hello, World ); } } Identificadores são usados
Programação Orientada a Objetos e Java - Introdução. Carlos Lopes
Programação Orientada a Objetos e Java - Introdução Carlos Lopes POO e Java Objetivo: proporcionar uma visão dos conceitos de POO e do seu uso na estruturação dos programas em Java. Classes e objetos em
Prova de Java. 1) Copie o programa abaixo no eclipse e complete-o, utilizando os conceitos aprendidos durante o curso. (4 pontos)
Prova de Java 1) Copie o programa abaixo no eclipse e complete-o, utilizando os conceitos aprendidos durante o curso. (4 pontos) O programa consiste em uma aplicação que simula o comportamento de dois
Capítulo 8. Introdução UML
Capítulo 8. Introdução UML 1/42 Índice Indice 8.1 - Introdução UML 8.2 - Modelação estrutural 8.2.1 - Representação de classes e objectos 8.2.2 - Relações entre objectos 8.2-3 - Relações de associação
ESQUEMA AULA PRÁTICA 1 Familiarização com o Ambiente de Desenvolvimento NetBeans Introdução à Linguagem de Programação JAVA
P. Fazendeiro & P. Prata POO FP1/1 ESQUEMA AULA PRÁTICA 1 Familiarização com o Ambiente de Desenvolvimento NetBeans Introdução à Linguagem de Programação JAVA 0 Iniciar o ambiente de desenvolvimento integrado
Conversão de Tipos e Arrays
Conversão de Tipos e Arrays Universidade Católica de Pernambuco Ciência da Computação Prof. Márcio Bueno [email protected] Fonte: Material da Profª Karina Oliveira Conversão de Tipos Permite converter
Programação com Objectos. Processamento de Dados I. 4. Classes Abstractas
Programação com Objectos Processamento de Dados I 4. Classes Abstractas 1 Conceito de classe abstracta Declaração de uma classe abstracta Implicações e características das classes abstractas Utilização
Especialização em desenvolvimento para web com interfaces ricas. Tratamento de exceções em Java Prof. Fabrízzio A. A. M. N. Soares
Especialização em desenvolvimento para web com interfaces ricas Tratamento de exceções em Java Prof. Fabrízzio A. A. M. N. Soares Objetivos Conceito de exceções Tratar exceções pelo uso de try, catch e
Herança. Algoritmos e Programação II. Aula 5 Herança
Algoritmos e Programação II Aula 5 Herança *Adaptado do material do Prof. Júlio Machado Herança Uma característica importante da programação orientada a objetos é permitir a criação de novas classes com
UNIVERSIDADE FEDERAL DO PARANÁ
CURSO: Ciência da Computação DATA: / / 2013 PERÍODO: 4 o. PROFESSOR: Andrey DISCIPLINA: Técnicas Alternativas de Programação AULA: 05 APRESENTAÇÃO: Nesta aula vamos ver como se faz a criação de Métodos
Reuso com Herança a e Composiçã
Java 2 Standard Edition Reuso com Herança a e Composiçã ção Helder da Rocha www.argonavis.com.br 1 Como aumentar as chances de reuso Separar as partes que podem mudar das partes que não mudam. Exemplo:
Universidade da Beira Interior. Sistemas Distribuídos
Folha 6-1 Sincronização de Threads A sincronização de Threads em Java é baseada no conceito do Monitor (de Hoare). Cada objecto Java tem associado um monitor (ou lock ) que pode ser activado se a palavra
Herança. Alberto Costa Neto DComp - UFS
Herança Alberto Costa Neto DComp - UFS 1 Motivação Vimos como se faz encapsulamento e a importância de fazê-lo... Contudo, também é possível fazer encapsulamento em algumas linguagens não OO O que mais
Sobre o Professor Dr. Sylvio Barbon Junior
5COP088 Laboratório de Programação Aula 1 Java Prof. Dr. Sylvio Barbon Junior Sylvio Barbon Jr [email protected] 1 Sobre o Professor Dr. Sylvio Barbon Junior Formação: Ciência e Engenharia da Computação (2005
Linguagem de Programação III
Linguagem de Programação III Aula-3 Criando Classes em Java Prof. Esbel Tomás Valero Orellana Da Aula Anterior Classes em Java, sintaxe básica Tipos básicos de dados em Java, como escolher o tipo apropriado
Curso de PHP. FATEC - Jundiaí. A programação orientada a objetos (object-oriented oriented programming
Curso de PHP FATEC - Jundiaí A programação orientada a objetos (object-oriented oriented programming OOP) é um conjunto de técnicas t para organizar o código c em torno de entidades ou objetos representados
Seminário - C# DSO II. Desenvolvimento de Sistemas Orientados a Objetos 2. Equipe: Diorges, Leonardo, Luís Fernando, Ronaldo
Seminário - C# DSO II Desenvolvimento de Sistemas Orientados a Objetos 2 Equipe: Diorges, Leonardo, Luís Fernando, Ronaldo Roteiro Breve Histórico Plataforma.NET Características da Linguagem Sintaxe Versões
Introdução à orientação a objetos. João Tito Almeida Vianna 25/05/2013
Introdução à orientação a objetos João Tito Almeida Vianna 25/05/2013 Roteiro Aula 2 Motivação Revisão dos conceitos da aula 1 Preparação para os exercícios Exercícios propostos 2 Motivação A orientação
ESQUEMA AULA PRÁTICA 1 Familiarização com o Ambiente de Desenvolvimento Eclipse Introdução à Linguagem de Programação JAVA
P. Fazendeiro & P. Prata POO FP1/1 ESQUEMA AULA PRÁTICA 1 Familiarização com o Ambiente de Desenvolvimento Eclipse Introdução à Linguagem de Programação JAVA 0 Inicie o ambiente de desenvolvimento integrado
Tópicos da Aula. Classes e Objetos. Classe Pública em Java. Classes em Java. Assinatura de Métodos. Corpo de Classes e Métodos. Conceitos de classe
DCC / ICEx / UFMG Tópicos da Aula Classes e Objetos Eduardo Figueiredo http://www.dcc.ufmg.br/~figueiredo Conceitos de classe Membros Construtores, métodos de classe e métodos de objeto, atributos de classe
Introdução a Java. Hélder Nunes
Introdução a Java Hélder Nunes 2 Exercício de Fixação Os 4 elementos básicos da OO são os objetos, as classes, os atributos e os métodos. A orientação a objetos consiste em considerar os sistemas computacionais
Programação com Acesso a BD. Programação com OO Acesso em Java
Programação com OO Acesso em Java a BD Curso: Técnico em Informática Campus: Ipanguaçu José Maria Monteiro Pontifícia Universidade Católica do Rio de Janeiro PUC-Rio Departamento Clayton Maciel de Informática
Desenvolvimento OO com Java Orientação a objetos básica
Desenvolvimento OO com Java Orientação a objetos básica Vítor E. Silva Souza ([email protected]) http://www.inf.ufes.br/~vitorsouza Departamento de Informática Centro Tecnológico Universidade Federal
Um objeto é uma instância de uma 'classe'. Você define uma classe utilizando o trecho de código abaixo;
um objeto; é definido; Um objeto é uma instância de uma 'classe'. Você define uma classe utilizando o trecho de código abaixo; class ClasseBase{ é instanciado; $objetobase = new ClasseBase; Caso queira,
Objetos Distribuídos - Programação Distribuída Orientado a Objetos. Luiz Affonso Guedes
Objetos Distribuídos - Programação Distribuída Orientado a Objetos Luiz Affonso Guedes Introdução Conceitos básicos programação distribuída + programação orientada a objetos = Objetos distribuídos Motivação
Sintaxe Geral Tipos de Dados. Prof. Angelo Augusto Frozza, M.Sc.
Sintaxe Geral Tipos de Dados Comentários Comentários: De linha: // comentário 1 // comentário 2 De bloco: /* linha 1 linha 2 linha n */ De documentação: /** linha1 * linha2 */ Programa Exemplo: ExemploComentario.java
Unidade IV: Ponteiros, Referências e Arrays
Programação com OO Acesso em Java a BD Curso: Técnico em Informática Campus: Ipanguaçu José Maria Monteiro Pontifícia Universidade Católica do Rio de Janeiro PUC-Rio Departamento Clayton Maciel de Informática
Orientação a Objetos em Java. Leonardo Gresta Paulino Murta [email protected]
Orientação a Objetos em Java Leonardo Gresta Paulino Murta [email protected] Agenda Introdução; Orientação a Objetos; Orientação a Objetos em Java; Leonardo Murta Orientação a Objetos em Java 2 Agosto/2007
PROGRAMAÇÃO ORIENTADA A OBJETOS -TRATAMENTO DE EXCEÇÕES. Prof. Angelo Augusto Frozza, M.Sc. [email protected]
PROGRAMAÇÃO ORIENTADA A OBJETOS -TRATAMENTO DE EXCEÇÕES Prof. Angelo Augusto Frozza, M.Sc. [email protected] ROTEIRO 5. Tratamento de Exceções Introdução e conceitos Capturando exceção usando
Implementação de Classe e Auto-Relacionamento em Java
UTFPR DAELN - Disciplina de Fundamentos de Programação II ( IF62C ). 1 Implementação de Classe e Auto-Relacionamento em Java 1)Introdução Um modelo de Diagrama de Classes representa a estrutura definida
15-09-2009. Membros de classe e de instância. PARTE III: Java e OO - detalhes. Exemplo 1: método. Exercício. Exemplo 1 corrigido
PARTE III: Java e OO - detalhes Membros de classe e instâncias Pacotes Visibilidade Classes aninhadas Membros de classe e de instância De classe Static Método não necessita de objeto para ser chamado.
Tabelas (arrays) (vetores, matrizes, etc) Algoritmos de pesquisa Algoritmos de ordenação
Java Tabelas (arrays) (vetores, matrizes, etc) Algoritmos de pesquisa Algoritmos de ordenação 1 Tabelas para quê? As tabelas são utilizadas quando se pretende armazenar e manipular um grande número de
Estrutura em Camadas. Estrutura em Camadas. Alcides Pamplona [email protected]. Alcides Pamplona Linguagem de Programação CESBD 2010
Alcides Pamplona Linguagem de Programação CESBD 2010 Alcides Pamplona [email protected] Tópicos Componentes da Estrutura Estruturando Aplicações OO em Camadas 2 Arquitetura em 1 camada Todas as
Aula 3 Objeto atual com referencia THIS e Classes com Herança
Aula 3 Objeto atual com referencia THIS e Classes com Herança Profº Msc. Alexsandro M. Carneiro Engenharia de Computação Tec. Análise e Des. De Sistemas Tópicos Abordados Controlee de Acesso Herança Definição:
Programação Avançada
Índice 1.1 - Introdução História A plataforma Java 1.2 - Conceitos Fundamentais na programação por objectos Objectos Encapsulamento Classes Herança Polimorfismo Interfaces Pacotes 1/24 1.1 Introdução 1.1
Revisão OO Básico. Orientação a Objetos em Java
Revisão OO Básico Orientação a Objetos em Java Grupo de Linguagens de Programação Departamento de Informática PUC-Rio Nomenclatura A unidade básica de programação em linguagens orientadas a objetos é a
Exemplo 1. Um programa que cria uma instância de uma classe que herda da classe Frame
6. Como aplicações gráficas funcionam em Java? Todas as aplicações gráficas em Java usam instâncias de classes existentes, que por serem parte da linguagem podem ser executadas em todas as versões de Java
Relacionamentos entre objetos. Relacionamentos entre objetos. Relacionamentos entre objetos. Relacionamentos entre objetos
Programação Orientada a Objetos Relacionamentos entre objetos Associação, composição e agregação Construtores e sobrecarga Variáveis de classe e de instância Reinaldo Gomes [email protected] Objetos
public Agenda() { compromissos = null; } public int getnumerodecompromissos() { if (compromissos==null) return 0; else return compromissos.
import java.util.scanner; class Data... class Compromisso... public class Agenda private Compromisso[] compromissos; private Compromisso[] realoquecompromissos (Compromisso[] vetor, int tamanhodesejado)
Programação com Objectos
Programação com Objectos PADRÕES DE DESENHO Classificaçã Objectivo Criação Estrutura Comportamento Introdução Alguns Padrões de Desenho Classe Factory Method Adapter Interpreter Template Method O que é
UNIVERSIDADE FEDERAL DO PARANÁ
CURSO: Ciência da Computação DATA: / / 2013 PERÍODO: 4 o. PROFESSOR: Andrey DISCIPLINA: Técnicas Alternativas de Programação AULA: 03 APRESENTAÇÃO: Hoje vamos conhecer o comando switch, o bloco try catch;
Módulo 02 Programação Orientada a Objetos. Última atualização: 07/06/2010
Módulo 02 Programação Orientada a Objetos Última atualização: 07/06/2010 1 Objetivos Definir conceitos de orientação a objetos: o abstração, encapsulamento, pacotes. Discutir reutilização de código em
Aula 09 Introdução à Java. Disciplina: Fundamentos de Lógica e Algoritmos Prof. Bruno Gomes http://www.profbrunogomes.com.br/
Aula 09 Introdução à Java Disciplina: Fundamentos de Lógica e Algoritmos Prof. Bruno Gomes http://www.profbrunogomes.com.br/ Agenda da Aula Java: Sintaxe; Tipos de Dados; Variáveis; Impressão de Dados.
