Faculdade de Ciências e Tecnologia

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-722­548­4.

- 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.

Cursos