
Programação Orientada pelos Objetos B
Código
11141
Unidade Orgânica
Faculdade de Ciências e Tecnologia
Departamento
Departamento de Informática
Créditos
6.0
Professor responsável
Luís Manuel Marques da Costa Caires, Miguel Jorge Tavares Pessoa Monteiro
Horas semanais
5
Língua de ensino
Português
Objectivos
Saber:
- Dominar os conceitos fundamentais de programação orientada ao objecto, como o de classe, interface, polimorfia e herança.
- Conhecer técnicas e algoritmos para o processamento de estruturas de dados tais como listas, cadeias de caracteres, vectores (arrays)
- Tirar partido de bibliotecas de classes disponíveis (e.g., classes colecção).
- Compreender os mecanismos essenciais de programação genérica.
Fazer:
- Projectar e desenvolver aplicações seguindo o paradigma de orientação pelos objectos.
- Resolver problemas, recorrendo ao paradigma estudado.
- Usar correctamente as abordagens de verificação e validação estudadas na cadeira.
- Realizar, individualmente e em grupo, projectos de desenvolvimento de software, integrando as várias competências transmitidas, de forma progressivamente mais autónoma.
Soft-Skills:
- Aprofundar hábitos de disciplina de trabalho e de cumprimento de prazos.
- Desenvolver a preocupação com o rigor, e com a execução sistemática de planos de trabalho e métodos previamente determinados.
- Desenvolver competências de organização de trabalho em grupo.
- Desenvolver o gosto pela programação e pela resolução de problemas de programação.
Pré-requisitos
É desejável que o aluno já tenha frequentado com sucesso uma disciplina introdutória da programação.
Conteúdo
Concepção de programas estruturados em classes.
Especificação de interfaces e respectiva documentação.
Polimorfismo de interfaces.
Herança de classes.
Polimorfismo de herança.
Utilização de tipos genéricos e colecções.
Tratamento de excepções e asserções.
Processamento de ficheiros de entrada/saída.
Bibliografia
- Cay Horstmann, Java Concepts, 4ª Edição (ou seguintes), Wiley, 2005, ISBN-10: 0471697044.
- F. Mário Martins, Java 5 e Programação por Objetos, FCA, 2006, ISBN 978-972-7225484.
- Diapositivos de Programação Orientada pelos Objetos (serão disponibilizados gradualmente na página moodle da cadeira).
NOTA IMPORTANTE: a leitura dos diapositivos não substitui a prática de programação no computador, que é ESSENCIAL para sucesso nesta disciplina.
Método de ensino
Todos os conhecimentos teóricos são facultados nas aulas teóricas e complementados com exercícios sugeridos nas aulas práticas. A cabal realização desses exercícios pode requerer tempo de treino fora das aulas.
O primeiro teste escrito (de dois) destina-se a avaliar os conhecimentos das regras da linguagem de programação que serve de suporte às aulas e ao trabalho prático.
O trabalho prático destina-se a por em prática os conhecimentos ministrados sobre a linguagem de programação e sobre o paradigma da programação orientada ao objecto; bem como adquirir a experiência prática de programação que sedimenta os conhecimentos teóricos.
O segundo teste escrito (de dois) destina-se a avaliar os conhecimentos adquiridos na disciplina, com foco no paradigma da programação orientada ao objecto ou na linguagem de programação enquanto veículo para materializar esses conhecimentos.
Método de avaliação
A edição 2018/19 de POO B tem 2 componentes na avaliação:
- 2 testes escritos, individuais e sem consulta, aos quais corresponde as notas NT1 e NT2 respectivamente. A componente da nota relativa aos testes - NT - corresponde a 65% da nota final. NT2 está sujeito a nota mínima de 9.5 para obtenção de aprovação à disciplina.
- Avaliação prática, aos quais corresponde uma nota prática - NP - que corresponde a 35% da nota final e é a componente da nota relativa a um trabalho prático, a realizar em grupos de dois alunos durante o semestre. NP é atribuída a cada aluno individualmente.
NT é obtida pela sua média ponderada de NT1 e NT2 da seguinte forma:
NT = ( 0,30 * NT1 + 0,35 * NT2 ) / 0.65
A nota final - NF - é determinada pela seguinte fórmula:
NF = 0,30 * NT1 + 0,35 * NT2 + 0,35 * NP
Frequência:
Obtém frequência à disciplina o aluno que tenha uma nota superior ou igual a 9.5 na NP.
O aluno sem frequência não obtém aprovação à disciplina e é excluído do exame de recurso.
Aprovação na época normal
O aluno com frequência obtém aprovação à disciplina, se as notas NF e NT2 (calculadas na escala 0-20) forem superiores ou iguais a 9.5.
Trabalho prático:
É realizado em grupos de dois alunos.
Seguindo o código de ética do Departamento de Informática, informa-se que se detectar que:
(1) um trabalho não foi realizado apenas pelos alunos que o entregaram; ou
(2) um aluno entregou um trabalho que não realizou; ou
(3) a distribuição das tarefas pelos membros do grupo mostra ter um desiquilíbrio significativo, as notas atribuídas aos dois elementos do grupo poderão ser distintas. Em casos extremos, o trabalho poderá anulado e nesse caso, nenhum dos elementos do(s) grupo(s) obtém aprovação na disciplina.
Exame de recurso:
NE é a nota obtida em exame de recurso (i.e., época de recurso), na presente edição da disciplina. Tem o mesmo peso, para o cálculo da nota final (NF), que os 2 testes: 65%.
A obtenção de aprovação em exame requer que NE >= 9.5.
Frequência anterior:
Os alunos que tenham obtido frequência na edição anterior da cadeira (ou seja, na edição da cadeira de 2017/18) podem mantê-la na presente edição caso o desejem. No entanto, para efeitos de avaliação neste semestre, caso entreguem o trabalho prático laboratorial perdem a frequência anterior. Nesse caso, aplicam-se as regras de avaliação definidas para alunos sem frequência.
Não será aproveitada qualquer nota da edição anterior respeitante à frequência. Os alunos com frequência da edição anterior e que a queiram manter, poderão ter algumas questões adicionais nos testes escritos, para efeitos de atribuição duma nota para o componente NP e com o mesmo peso. Caso não haja questões adicionais nos testes, NF será igual a NT.
Para alunos com frequência da edição anterior , há 2 cenários alternativos: (1) comparecer aos 2 testes para obtenção de NT; ou ir a exame para obter a NE. A nota final é calculada utilizando na fórmula para o cálculo de NF:
NF = (NT1 * 0.30 + NT2 * 0.35)/0.65 se compareceram aos 2 testes, se NF >= 9.5 e se NT2 >= 9.5, ou:
NF = NE se compareceram ao exame de recurso e se NE >= 9.5.
Melhoria de nota:
Os alunos que tenham obtido aprovação na avaliação contínua deste semestre podem usar o exame para melhorar a NF. Nesse caso, a nota de exame NE substitui a nota NT na fórmula de cálculo de NF. Como requisito de melhoria de nota, estabelece-se que a nota NF resultante da NE seja superior à NF resultante da NT.
As melhorias de nota, para os alunos que obtiveram aprovação numa edição anterior, a nota final será a nota obtida no exame (NF = NE). No caso de haver perguntas especificamente para a parte da NP, para os alunos com frequência anterior, os candidatos a melhoria deverão responder também a essas questões, nos mesmos termos.
As classificações relativas a testes e demais elementos de avaliação são expressas num escala de 0 a 20, arredondadas às centésimas. Os arrendondamentos para valores inteiros são feitos no cálculo da NF.