Aula 04 - Diagramas UML (Diagramas de Classes)

Fazer download em pdf ou txt
Fazer download em pdf ou txt
Você está na página 1de 36

Unified Modeling Language (UML)

- Diagrama de Classes

Félix Macueia
Diagrama de
Classes
Aplicação

A UML adoptou também o diagrama de classes, uma das


técnicas mais utilizadas no desenvolvimento orientado por
objectos. Este diagrama é uma descrição formal da
estrutura de objectos num sistema. Para cada objecto
descreve a sua identidade, os seus relacionamentos com
os outros objectos, os seus atributos e as suas operações.
Notação

Um diagrama de classes é composto pelos seguintes


elementos abstractos de modelação:

- Classes de objectos
- Relações de Associação e Generalização
- Multiplicidade
O que modelar?

Aqui os diagramas são elaborados na perspectiva de


modelar as classes do sistema e as suas relações.
Aproveitando o exemplo apresentado no diagrama de Use
Case, poderíamos acrescentar a seguinte descrição:
"Um cliente pode efectuar muitas encomendas, contendo cada
encomenda diversos itens, numerados sequencialmente, que se
referem a um determinado produto e respectiva quantidade
encomendada. Os produtos vendidos pela PhonePizza abrangem
pizzas com diversos tamanhos (Pequena, Média e Grande),
bebidas e saladas. O preço pode variar conforme o tamanho do
produto bem como com as promoções existentes que têm uma
data de início e de fim."
O que é um Objecto?

É caracterizado por um conjunto de Propriedades, um Comportamento e


Identidade.
- As Propriedades são as características que definem o objecto,
transpostas para um conjunto de atributos, cujos valores estabelecem o
Estado do objecto.
- O Comportamento é definido como as operações que o objecto pode
efectuar.
- A Identidade permite identificar um objecto em particular como único
num conjunto de objectos semelhantes.
O que é um Objecto?
O que é uma Classe?

Representa uma abstracção sobre um conjunto de objectos que


partilham a mesma estrutura e comportamento. Na prática, um
objecto é um caso particular de uma classe, também referido como
uma instância da classe.
O que é uma Classe?

No exemplo anterior poderíamos resumir os diferentes objectos num


conjunto de propriedades e operações comuns.
O que é uma Classe?

As instâncias da classe (objectos) podem ser representadas da


seguinte forma:
Visibilidade

Tanto os atributos como as operações podem ser visíveis ou não para


outras classes. Esta propriedade denomina-se visibilidade e assume 3
níveis:
* Público - Qualquer classe tem acesso ao elemento. É representado
através do prefixo +.
* Protegido - Qualquer descendente da classe pode utilizar o elemento.
É representado através do prefixo #.
* Privado - Apenas a própria classe tem acesso ao elemento. É
representado através do prefixo -.
Visibilidade

Conjunto de elementos públicos, privados e protegidos para a classe


Cliente:
Tipos de dados básicos

Integer - Representa um número inteiro.


Long - Representa um número inteiro mas de maior dimensão.
Double - Para números reais.
String - Representa texto.
Date - Para datas.
Boolean - Valor lógico que representa
Verdade ou Falso.
Associações

No diagrama de classes, as associações representam as relações entre


os objectos. As associações são caracterizadas por possuir um nome e
quando necessário podem também incluir o papel que os objectos têm
na relação.
Associação na mesma Classe
Multiplicidade

Indica a quantidade de objectos que participam numa relação.

0..1 - Opcional.
1..1 - Obrigatório existir um objecto, frequentemente representado por
apenas 1.
1..10 - Um valor entre o intervalo estabelecido, neste caso de um a dez.
0..* - Zero ou infinitos objectos da classe, também representado
por apenas *.
1..* - Um ou infinitos objectos da classe.
Multiplicidade
Identificação de classes

A identificação das classes não é um processo directo sendo, por


vezes, necessárias diversas iterações e refinamentos até identificar
correctamente todas as classes. Uma regra simples para começar o
processo de identificação é sublinhando na descrição dos use cases os
substantivos.
Identificação de classes

A identificação das classes não é um processo directo sendo, por


vezes, necessárias diversas iterações e refinamentos até identificar
correctamente todas as classes. Uma regra simples para começar o
processo de identificação é sublinhando na descrição dos use cases os
substantivos.
Identificação de classes
Identificação de classes
Identificação de classes

Com o procedimento anterior teríamos identificado as seguintes


classes: Cliente, Encomenda, Catálogo de Produtos, Cartão de
Credito, Produto.

Após a identificação preliminar é necessário efectuar uma pequena


descrição para cada classe e ao mesmo tempo proceder a uma
triagem com base nos seguintes critérios: Fora do âmbito do sistema,
Representa o sistema, Classes semelhantes, Nível de detalhe.
Identificação de atributos

Os atributos são características das classes que facilmente surgem na


descrição dos use cases. Alguns atributos não são explicitamente
referidos nas descrições, mas surgem do conhecimento do domínio
como, por exemplo, o nome ou a morada de um cliente.
Identificação de atributos
Identificação de associações e operações

As associações podem ser identificadas com base nas relações


lógicas entre as classes. Também podem ser identificadas na
descrição dos use cases através dos verbos como, por exemplo, "o
cliente efectua encomendas".

Contudo, só é possível compreender na totalidade as associações


através de uma análise das interacções entre os objectos das classes.
Este é o método também usado para a definição das operações.
Identificação de associações e operações
Restrições

As restrições no diagrama de classes, apenas devem ser


representadas utilizando as chavetas "{}".
Classes Associativas

Este tipo de classes surge da necessidade de reforçar o detalhe de


informação de uma associação. É representado da seguinte forma:
Generalização e Herança
Agregação e Composição

A agregação no diagrama de classes pretende demonstrar o facto de


que um todo é composto por partes.
Agregação e Composição

A composição é uma agregação com um significado mais forte


existindo uma dependência directa entre as duas classes (se a parte
deixar de existir, o todo também deixa de existir).
Perguntas de revisão
1: Qual é o objectivo de um diagrama de classes?
2: O que significa uma classe?
3: Qual é a notação para uma classe?
4: O que é um objecto?
5: Qual é a notação para um objecto?
6: Defina os conceitos de atributo e operações numa classe?
7: Em que consiste a visibilidade de um atributo?
8: Que tipos básicos podem assumir os atributos?
9: O que significa uma associação entre classes?
10: Defina o conceito de multiplicidade numa associação?
11: O que é uma classe associativa?
12: Qual a principal diferença entre a generalização, agregação e
composição?
Material para leitura
1: Estereótipos de diagramas de classes?
2: Diagramas de objecto.

(Livro “UML UMA ABORDAGEM PRÁTICA” disponível na pasta do Drive)


Obrigado
Têm perguntas?

Você também pode gostar