1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
|
<chapter id="uml-basics">
<title
>Bases de &UML;</title>
<sect1 id="about-uml">
<title
>Acerca do &UML;</title>
<para
>Este capítulo dar-lhe-á uma ideia geral sobre as bases do &UML;. Tenha em mente que isto não é um tutorial compreensivo sobre o &UML; mas sim uma breve introdução ao mesmo, como tal poderá ser lido como um tutorial de &UML;. Se você quiser aprender mais sobre a Unified Modelling Language ou, na generalidade, sobre a análise e desenho de 'software', baseie-se num dos vários livros disponíveis sobre o tópico. Existem também vários tutoriais na Internet que você poderá usar como ponto de partida. </para>
<para
>A Unified Modelling Language (&UML;) é uma linguagem ou notação de diagramas para especificar, visualizar e documentar modelos de 'software' orientados por objectos. O &UML; não é um método de desenvolvimento, o que significa que não lhe diz o que fazer primeiro ou o que fazer a seguir ou como desenhar o seu sistema, mas ajuda-o a visualizar o seu desenho e a comunicar com os outros. O &UML; é controlado pelo Object Management Group (<acronym
>OMG</acronym
>) e é a norma da indústria para descrever graficamente o 'software'. </para>
<para
>O &UML; está desenhado para o desenho de 'software' orientado por objectos e tem uma utilização limitada para outros paradigmas de programação. </para>
<para
>O &UML; é composto por vários elementos do modelo que representam as diferentes partes de um sistema de 'software'. Os elementos de &UML; são usados para criar diagramas que representam uma dada parte ou um ponto de vista do sistema. São suportados os seguintes tipos de diagramas pelo &umbrello;: </para>
<itemizedlist>
<listitem
><para
>Os <emphasis
><link linkend="use-case-diagram"
>Diagramas de Casos de Uso</link
></emphasis
> mostram os actores (as pessoas ou os outros utilizadores do sistema), os casos de utilização (os cenários em que eles usam o sistema) e as suas relações</para
> </listitem>
<listitem
><para
>Os <emphasis
><link linkend="class-diagram"
>Diagramas de Classes</link
></emphasis
> mostram as classes e as relações entre elas</para
> </listitem>
<listitem
><para
>Os <emphasis
><link linkend="sequence-diagram"
>Diagramas de Sequência</link
></emphasis
> mostram os objectos e uma sequência de chamadas de métodos que eles fazem a outros objectos.</para
> </listitem>
<listitem
><para
>Os <emphasis
><link linkend="collaboration-diagram"
>Diagramas de Colaboração</link
></emphasis
> mostram os objectos e as suas relações, colocando alguma ênfase nos objectos que participam na troca de mensagens</para>
</listitem>
<listitem
><para
>Os <emphasis
><link linkend="state-diagram"
>Diagramas de Estados</link
></emphasis
> mostram os estados, as mudanças de estado e os eventos num objecto ou numa parte do sistema</para
> </listitem>
<listitem
><para
>Os <emphasis
><link linkend="activity-diagram"
>Diagramas de Actividades</link
></emphasis
> mostram as actividades e as mudanças de uma actividade para outra com os eventos a ocorrerem numa parte do sistema</para
></listitem>
<listitem
><para
>Os <emphasis
><link linkend="component-diagram"
>Diagramas de Componentes</link
></emphasis
> mostram os componentes de alto-nível de programação (como as KParts ou os Java Beans).</para
></listitem>
<listitem
><para
>Os <emphasis
><link linkend="deployment-diagram"
>Diagramas de Entradas em Produção</link
></emphasis
> mostram as instâncias dos componentes e as suas relações.</para
></listitem
>
</itemizedlist>
</sect1
> <!-- about-uml -->
<sect1 id="uml-elements"
>
<title
>Elementos de &UML;</title>
<sect2 id="use-case-diagram">
<title
>Diagrama de Casos de Utilização</title>
<para
>Os Diagramas de Casos de Uso descrevem as relações e as dependências entre um grupo de <emphasis
>Casos de Uso</emphasis
> e os Actores que participam no processo.</para>
<para
>É importante reparar que os Diagramas de Casos de Uso não são adequados para representar o desenho e também não podem descrever os detalhes internos de um sistema. Os Diagramas de Casos de Uso pretendem facilitar a comunicação com os utilizadores futuros do sistema e com o cliente, e são especialmente úteis para determinar as funcionalidades necessárias que o sistema deverá ter. Os Diagramas de Casos de Uso indicam <emphasis
>o que</emphasis
> o sistema deverá fazer mas não devem — e não podem — especificar <emphasis
>como</emphasis
> isto deverá ser feito.</para>
<para>
<screenshot>
<screeninfo
>Um exemplo de diagrama de Casos de Utilização.</screeninfo>
<mediaobject>
<imageobject>
<imagedata fileref="use-case-diagram.png" format="PNG"/>
</imageobject>
<textobject>
<phrase
>&umbrello; a mostrar um diagrama de Casos de Utilização</phrase>
</textobject>
<caption>
<para
>&umbrello; a mostrar um diagrama de Casos de Utilização </para>
</caption>
</mediaobject>
</screenshot>
</para>
<sect3 id="use-case">
<title
>Caso de Utilização</title>
<para
>Um <emphasis
>Caso de Utilização</emphasis
> descreve — do ponto de vista dos actores — um grupo de actividades de um sistema que produzem um resultado concreto e tangível.</para>
<para
>Os Casos de Uso são descrições das interacções típicas entre os utilizadores de um sistema e o sistema propriamente dito. Eles representam a interface externa do sistema e especificam um dado tipo de requisitos sobre o que o sistema tem de fazer (lembre-se, só 'o quê', não 'como'). </para>
<para
>Ao lidar com os Casos de Uso, é importante recordar algumas regras simples: <itemizedlist>
<listitem
><para
>Cada Caso de Utilização está relacionado com pelo menos um actor</para
></listitem>
<listitem
><para
>Cada Caso de Utilização tem um iniciador (ou seja, um actor)</para
></listitem>
<listitem
><para
>Cada Caso de Uso conduz a um resultado relevante (um resultados com <quote
>valor de negócio</quote
>)</para>
</listitem>
</itemizedlist>
</para>
<para
>Os Casos de Uso também poderão ter relações com outros Casos de Uso. Os três tipos de relações mais típicos entre Casos de Uso são:</para>
<itemizedlist>
<listitem
><para
><emphasis
><<include>> (incluir)</emphasis
> que indica que um Caso de Uso toma lugar <emphasis
>dentro</emphasis
> de outro Caso de Uso</para
></listitem>
<listitem
><para
><emphasis
><<extends>> (extende)</emphasis
> que indica que, em certas situações ou numa dada altura (chamada de ponto de extensão), um Caso de Uso será extendido por outro.</para
></listitem>
<listitem
><para
><emphasis
>Generalization</emphasis
> (generalização) indica que um Caso de Uso herda as características do <quote
>Super</quote
>-Caso de Uso e poderá implementar novamente algumas delas ou adicionar novas de uma forma semelhante à da herança de classes. </para>
</listitem>
</itemizedlist>
</sect3>
<sect3 id="actor">
<title
>Actor</title>
<para
>Um actor é uma entidade externa (fora do sistema) que interage com o sistema ao participar (ou iniciar normalmente) um Caso de Uso. Os actores poderão ser pessoas reais (como, por exemplo, utilizadores do sistema), outros sistemas informáticos ou eventos exteriores. </para>
<para
>Os actores não representam as pessoas <emphasis
>físicas</emphasis
> ou os sistemas, mas sim o seu <emphasis
>papel</emphasis
>. Isto significa que, quando uma pessoa interage com o sistema de formas diferentes (assumindo papéis diferentes), ele será representado por vários actores. Por exemplo, uma pessoa que dá suporte ao cliente por telefone e que recebe encomendas do cliente para colocar no sistema seria representado por um actor <quote
>Técnico de Suporte</quote
> e por um actor <quote
>Representante de Vendas</quote
> </para>
</sect3>
<sect3 id="use-case-description">
<title
>Descrição de Caso de Utilização</title>
<para
>As descrições dos Casos de Uso são narrativas textuais do Caso de Uso. Elas normalmente tomam a forma de uma nota ou de um documento que esteja associado de alguma forma ao Caso de Uso e explicam os processos ou actividades que tomam lugar no Caso de Uso. </para>
</sect3>
</sect2
> <!-- use-case-diagram -->
<sect2 id="class-diagram">
<title
>Diagrama de Classes</title>
<para
>Os Diagramas de Classes mostram as diferentes classes que compõem um sistema e como elas se relacionam umas com as outras. Os Diagramas de Classes são apontados normalmente como <quote
>estáticos</quote
> porque mostram as classes, em conjunto com os seus métodos e atributos, assim como as relações estáticas entre elas, quais as classes que <quote
>conhecem</quote
> outras classes ou que <quote
>fazem parte</quote
> de outra classe, mas não mostram as chamadas de métodos entre elas. </para>
<para>
<screenshot>
<screeninfo
>Um exemplo de um Diagrama de Classes</screeninfo>
<mediaobject>
<imageobject>
<imagedata fileref="class-diagram.png" format="PNG"/>
</imageobject>
<textobject>
<phrase
>O &umbrello; a mostrar um diagrama de Classes</phrase>
</textobject>
<caption>
<para
>O &umbrello; a mostrar um diagrama de Classes </para>
</caption>
</mediaobject>
</screenshot>
</para>
<sect3 id="class">
<title
>Classe</title>
<para
>Uma classe define os atributos e os métodos para um conjunto de objectos. Todos os objectos desta classe (as instâncias da mesma) partilham o mesmo comportamento e têm o mesmo conjunto de atributos (cada objecto tem o seu próprio conjunto). O termo <quote
>Tipo</quote
> é usado em algumas ocasiões em vez de Classe, mas é importante mencionar que os dois conceitos não são iguais e que o Tipo é um termo mais genérico. </para>
<para
>No &UML;, as Classes são representadas por rectângulos com o nome da classe, e poderão também mostrar os atributos e as operações da classe em outros dois <quote
>compartimentos</quote
> dentro do rectângulo. </para>
<para>
<screenshot>
<screeninfo
>Uma Classe em &UML;</screeninfo>
<mediaobject>
<imageobject>
<imagedata fileref="class.png" format="PNG"/>
</imageobject>
<textobject>
<phrase
>Representação visual de uma Classe em &UML;</phrase>
</textobject>
<caption>
<para
>Representação visual de uma Classe em &UML; </para>
</caption>
</mediaobject>
</screenshot>
</para>
<sect4 id="attribute">
<title
>Atributos</title>
<para
>No &UML;, os Atributos são mostrados como tendo o seu nome, pelo menos, e poderão mostrar também o seu tipo, o seu valor inicial e outras propriedades. Os atributos também poderão ser mostrados com a sua visibilidade: </para>
<itemizedlist>
<listitem
><para
><literal
>+</literal
> Representa atributos <emphasis
>públicos</emphasis
></para
></listitem>
<listitem
><para
><literal
>#</literal
> Representa atributos <emphasis
>protegidos</emphasis
></para
></listitem>
<listitem
><para
><literal
>-</literal
> Representa atributos <emphasis
>privados</emphasis
></para
></listitem>
</itemizedlist>
</sect4>
<sect4 id="operation">
<title
>Operações</title>
<para
>As operações (métodos) são também mostradas contendo pelo menos o seu nome e poderão também mostrar os seus parâmetros e tipos de valor devolvidos. As operações podem, assim como os Atributos, mostrar a sua visibilidade: <itemizedlist>
<listitem
><para
><literal
>+</literal
> Corresponde a operações <emphasis
>públicas</emphasis
></para
></listitem>
<listitem
><para
><literal
>#</literal
> Corresponde a operações <emphasis
>protegidas</emphasis
></para
></listitem>
<listitem
><para
><literal
>-</literal
> Corresponde a operações <emphasis
>privadas</emphasis
></para
></listitem>
</itemizedlist>
</para>
</sect4>
<sect4 id="templates">
<title
>Modelos</title>
<para
>As Classes poderão ter modelos, um valor que é usado para uma classe ou tipo não especificado. O tipo de modelo é definido quando uma classe é iniciada (&ie; um objecto é criado). Os modelos existem como 'template' no C++ actual e serão introduzidos no Java 1.5 onde serão chamados de 'Generics'. </para>
</sect4>
</sect3>
<sect3 id="class-associations">
<title
>Associações da Classe</title>
<para
>Uma classe pode-se relacionar (ser associada) com outra qualquer de diferentes maneiras:</para>
<sect4 id="generalization">
<title
>Generalização</title>
<para
>A herança é um dos conceitos fundamentais da programação orientada por objectos, nos quais uma classe <quote
>ganha</quote
> todos os atributos e operações da classe que herda, podendo sobrepor ou modificar algumas delas, assim como adicionar mais atributos ou operações próprias.</para>
<para
>No &UML;, uma associação por <emphasis
>Generalização</emphasis
> entre duas classes representa o conceito de herança entre uma classe de base e uma classe derivada. No &UML;, as Generalizações são representadas com uma linha que liga as duas classes, em que existe uma seta do lado da classe de base. <screenshot>
<screeninfo
>Generalização</screeninfo>
<mediaobject>
<imageobject>
<imagedata fileref="generalization.png" format="PNG"/>
</imageobject>
<textobject>
<phrase
>Representação visual de uma generalização em &UML;</phrase>
</textobject>
<caption>
<para
>Representação visual de uma generalização em &UML; </para>
</caption>
</mediaobject>
</screenshot>
</para>
</sect4>
<sect4 id="uml-associations">
<title
>Associações</title>
<para
>Uma associação representa uma relação entre classes e dá a semântica e a estrutura comum para vários tipos de <quote
>ligações</quote
> entre os objectos.</para>
<para
>As associações são o mecanismo que permite aos objectos comunicarem uns com os outros. Descreve a ligação entre as diferentes classes (a ligação entre os objectos em si é chamada de <emphasis
>ligação do objecto</emphasis
>. </para>
<para
>As associações podem ter um papel que indica o objectivo da associação e pode ser unidireccionais ou bidireccionais (indica se os dois objectos que participam na relação poderão enviar mensagens um para o outro, ou se só um deles é que conhece o outro). Cada extremo da associação também tem um valor de multiplicidade, que define quantos objectos desse lado da associação poder-se-ão relacionar com um objecto do outro lado. </para>
<para
>No &UML;, as associações são representadas como linhas que ligam as classes que participam na relação e poderá também mostrar o papel e a multiplicidade de cada um dos participantes. A multiplicidade é mostrada como um intervalo [mín..máx] de valores não-negativos ou com um asterisco (<literal
>*</literal
>) no lado do máximo que representa o infinito. <screenshot>
<screeninfo
>Associação &UML;</screeninfo>
<mediaobject>
<imageobject>
<imagedata fileref="association.png" format="PNG"/>
</imageobject>
<textobject>
<phrase
>Uma representação visual de uma associação em &UML;</phrase>
</textobject>
<caption>
<para
>Uma representação visual de uma associação em &UML; </para>
</caption>
</mediaobject>
</screenshot>
</para>
</sect4>
<sect4 id="aggregation">
<title
>Agregação</title>
<para
>As agregações são um tipo especial de associações nas quais as duas classes participantes não têm um estado igual, mas têm uma relação <quote
>do 'todo' para as partes</quote
>. Uma agregação diz como é que a classe que têm o papel do 'todo' é composta (ou tem) as outras classes, que têm o papel das partes. Para as agregações, a classe que actua como o 'todo' tem sempre uma multiplicidade de um. </para>
<para
>No &UML;, as agregações são representados por uma associação com um losango do lado do 'todo'. <screenshot>
<screeninfo
>Agregação</screeninfo>
<mediaobject>
<imageobject>
<imagedata fileref="aggregation.png" format="PNG"/>
</imageobject>
<textobject>
<phrase
>Uma representação visual de uma relação de agregação no &UML;</phrase>
</textobject>
<caption>
<para
>Uma representação visual de uma relação de agregação no &UML; </para>
</caption>
</mediaobject>
</screenshot>
</para>
</sect4>
<sect4 id="composition">
<title
>Composição</title>
<para
>As composições são associações que representam agregações <emphasis
>muito fortes</emphasis
>. Isto significa que as composições formam também relações do 'todo' para as partes, mas a relação é tão forte que as partes não podem existir por si só. Elas só existem dentro do todo e se o todo for destruído, as partes desaparecem também.</para>
<para
>No &UML;, as Composições são representadas por um losango a cheio do lado do 'todo'. </para>
<para
><screenshot>
<screeninfo
>Composição</screeninfo>
<mediaobject>
<imageobject>
<imagedata fileref="composition.png" format="PNG"/>
</imageobject>
<textobject>
<phrase
>Uma representação visual de uma relação de Composição no &UML;</phrase>
</textobject>
</mediaobject>
</screenshot
></para>
</sect4>
</sect3
> <!--class-associations-->
<sect3 id="other-class-diagram-items">
<title
>Outros Itens do Diagrama de Classes</title>
<para
>Os diagramas de classe poderão conter outros itens para além das classes.</para>
<sect4 id="interfaces">
<title
>Interfaces</title>
<para
>As interfaces são classes abstractas, o que significa que as instâncias não podem ser criadas directamente a partir delas. Elas poderão contem operações, mas não podem conter atributos. As classes podem herdar das interfaces (através de uma relação de realização) e as instâncias poderão então ser compostas a partir dessas classes.</para>
<!-- FIXME screenshot -->
</sect4>
<sect4 id="datatype">
<title
>Tipos de dados</title>
<para
>Os tipos de dados são primitivas que vêm tipicamente incorporadas numa linguagem de programação. Os exemplos comuns incluem os inteiros e os booleanos. Eles não poderão ter relações com as classes, mas as classes poderão ter relações com eles.</para>
<!-- FIXME screenshot -->
</sect4>
<sect4 id="enum">
<title
>Enumerados</title>
<para
>Os enumerados são uma lista simples de valores. Um exemplo típico são os enumerados para os dias da semana. Como os tipos de dados, os enumerados não poderão ter relações com as classes, mas as classes poderão ter relações com eles.</para>
<!-- FIXME screenshot -->
</sect4>
<sect4 id="package">
<title
>Pacotes</title>
<para
>Os pacotes representam um espaço de nomes numa linguagem de programa. Num diagrama, eles são usados para representar partes de um sistema que contém mais do que uma classe, podendo ser mesmo centenas de classes.</para>
<!-- FIXME screenshot -->
</sect4>
</sect3>
</sect2
> <!-- class diagram -->
<sect2 id="sequence-diagram">
<title
>Diagramas de Sequência</title>
<para
>Os Diagramas de Sequência mostram a troca de mensagens (&ie; as chamadas aos métodos) entre os vários objectos numa situação específica delimitada no tempo. Os objectos são instâncias das classes. Os Diagramas de Sequência colocam uma ênfase especial na ordem e nas alturas em que as mensagens são enviadas para os objectos.</para>
<para
>Nos Diagramas de Sequência, os objectos são representados através de linhas tracejadas verticais, com o nome do objecto no topo. O eixo do tempo também é vertical, e vai aumentando de cima para baixo, de modo a que as mensagens sejam enviadas de um objecto para outro, sob o formato de setas com o nome da operação e dos parâmetros. </para>
<!-- FIXME update screenshot to show synchronous messages -->
<screenshot>
<screeninfo
>Diagrama de Sequência</screeninfo>
<mediaobject>
<imageobject>
<imagedata fileref="sequence-diagram.png" format="PNG"/>
</imageobject>
<textobject>
<phrase
>O &umbrello; a mostrar um Diagrama de Sequência</phrase>
</textobject>
<caption>
<para
>O &umbrello; a mostrar um Diagrama de Sequência </para>
</caption>
</mediaobject>
</screenshot>
<para
>As mensagens tanto podem ser síncronas, o que acontece normalmente nas chamadas de mensagens quando o controlo é passado para o objecto que é invocado até que esse método termine a sua execução, ou poderão também ser assíncronas, onde o controlo é passado de volta directamente para o objecto que invoca o método. As mensagens síncronas têm uma caixa vertical do lado do objecto que é chamado para mostrar o fluxo de controlo do programa.</para>
</sect2
> <!-- sequence diagrams -->
<sect2 id="collaboration-diagram">
<title
>Diagramas de Colaboração</title>
<para
>Os Diagramas de Colaboração mostram as interacções entre os objectos que participam numa dada situação. Esta é mais ou menos a mesma informação que é mostrada pelos Diagramas de Sequência, mas existe também uma ênfase posta sobre como as interacções ocorrem no tempo, enquanto que os Diagramas de Colaboração colocam as relações entre os seus objectos e a sua topologia em primeiro plano.</para>
<para
>Nos Diagramas de Colaboração, as mensagens enviadas de um objecto para o outro são representadas por setas que mostram o nome da mensagem, os parâmetros e a sequência da mensagem. Os Diagramas de Colaboração são particularmente adequados a mostrar um fluxo específico de um programa ou situação, e são uns dos melhores tipos de diagramas para demonstrar ou explicar rapidamente um processo na lógica do programa. </para>
<screenshot>
<screeninfo
>Colaboração</screeninfo>
<mediaobject>
<imageobject>
<imagedata fileref="collaboration-diagram.png" format="PNG"/>
</imageobject>
<textobject>
<phrase
>O &umbrello; a mostrar um Diagrama de Colaboração</phrase>
</textobject>
<caption>
<para
>O &umbrello; a mostrar um Diagrama de Colaboração </para>
</caption>
</mediaobject>
</screenshot>
</sect2
> <!-- collaboration diagrams -->
<sect2 id="state-diagram">
<title
>Diagramas de Estados</title>
<para
>Os Diagramas de Estados mostram os diferentes estados de um objecto durante a sua vida, bem como os estímulos que fazem com que o objecto mude o seu estado. </para
>
<para
>Os Diagramas de Estados vêem os objectos como <emphasis
>máquinas de estados</emphasis
> ou autónomos finitos que poderão estar num estado pertencente a uma lista de estados finitos e que poderão mudar o seu estado através de um estímulo pertencente a um conjunto finito de estímulos. Por exemplo, um objecto do tipo <emphasis
>ServidorRede</emphasis
> poderá estar num dos seguintes estados durante a sua vida: </para>
<itemizedlist>
<listitem
><para
>Pronto</para
></listitem>
<listitem
><para
>À espera</para
></listitem>
<listitem
><para
>A trabalhar</para
></listitem>
<listitem
><para
>Parado</para
></listitem>
</itemizedlist>
<para
>e os eventos que poderão fazer com que o Objecto mude de estado são</para>
<itemizedlist>
<listitem
><para
>O objecto é criado</para
></listitem>
<listitem
><para
>O objecto atende a mensagem</para
></listitem>
<listitem
><para
>Um cliente pede uma ligação pela rede</para
></listitem>
<listitem
><para
>Um cliente termina um pedido</para
></listitem>
<listitem
><para
>O pedido é executado e terminado</para
></listitem>
<listitem
><para
>O objecto recebe a mensagem parar</para
></listitem>
<listitem
><para
>etc</para
></listitem>
</itemizedlist>
<para>
<screenshot>
<screeninfo
>Diagrama de Estado</screeninfo>
<mediaobject>
<imageobject>
<imagedata fileref="state-diagram.png" format="PNG"/>
</imageobject>
<textobject>
<phrase
>O &umbrello; a mostrar um Diagrama de Estado</phrase>
</textobject>
<caption>
<para
>O &umbrello; a mostrar um Diagrama de Estado </para>
</caption>
</mediaobject>
</screenshot>
</para>
<sect3 id="state">
<title
>Estado</title>
<para
>Os estados são os blocos de construção dos Diagramas de Estado. Um estado pertence a exactamente uma classe e representa um resumo dos valores que os atributos de uma classe poderão obter. Um Estado no &UML; descreve o estado interno de um objecto de uma determinada classe </para
>
<para
>Tenha em atenção que nem todas as alterações de um atributo de um objecto deverão ser representadas por um estado, mas só mesmo aquelas alterações que poderão afectar significativamente o funcionamento do objecto</para>
<para
>Existem dois tipos especiais de Estados: o Inicial e o Final. Eles são especiais na medida em que não existe nenhum evento que possa fazer um objecto voltar ao seu estado inicial, da mesma forma que não há nenhum evento que possa retirar um objecto do seu estado final, logo que o tenha atingido. </para>
</sect3>
</sect2
> <!-- state diagrams -->
<sect2 id="activity-diagram">
<title
>Diagrama de Actividades</title>
<para
>Os Diagramas de Actividades descrevem a sequência de actividades de um sistema, com a ajuda das Actividades propriamente ditas. Os Diagramas de Actividades são um tipo especial de Diagramas de Estados, que só (ou em grande parte) contêm Actividades. </para>
<para>
<screenshot>
<screeninfo
>Um exemplo de Diagrama de Actividades.</screeninfo>
<mediaobject>
<imageobject>
<imagedata fileref="activity-diagram.png" format="PNG"/>
</imageobject>
<textobject>
<phrase
>O &umbrello; a mostrar um Diagrama de Actividade</phrase>
</textobject>
<caption>
<para
>O &umbrello; a mostrar um Diagrama de Actividade </para>
</caption>
</mediaobject>
</screenshot>
</para>
<para
>Os Diagramas de Actividades são semelhantes aos fluxogramas procedimentais, com a diferença que todas as Actividades estão claramente associadas a objectos.</para>
<para
>Os Diagramas de Actividades estão sempre associados a uma <emphasis
>Classe</emphasis
>, uma <emphasis
>Operação</emphasis
> ou um <emphasis
>Caso de Uso</emphasis
>.</para>
<para
>Os Diagramas de Actividades suportam as Actividades sequências, assim como as paralelas. A execução paralela é representada através de ícones de 'Fork' (Bifurcação) ou 'Wait' (Espera) e, para as actividades que decorrem em paralelo, não é importante a ordem pela qual são desempenhadas (elas poderão ser executadas ao mesmo tempo ou uma a seguir à outra)</para>
<sect3 id="activity">
<title
>Actividade</title>
<para
>Uma Actividade é um passo único num processo. Uma Actividade é um estado no sistema com actividade interna e, pelo menos, uma transição de saída. As Actividades também poderão conter mais do que uma transição de saída se tiverem diferentes condições. </para
>
<para
>As Actividades poderão formar hierarquias, o que significa que uma Actividade poderá ser composta por várias Actividades de <quote
>detalhe</quote
>, onde nesse caso as transições de entrada e de saída deverão corresponder às transições de entrada e de saída do diagrama de detalhe. </para>
</sect3>
</sect2
> <!-- activity diagram -->
<sect2 id="helper-elements">
<title
>Elementos Auxiliares</title>
<para
>Existem alguns elementos no &UML; que não têm nenhum valor semântico real para o modelo, mas que ajudam a clarificar partes do diagrama. Esses elementos são </para>
<itemizedlist>
<listitem
><para
>Linhas de texto</para
></listitem>
<listitem
><para
>Notas de Texto e âncoras</para
></listitem>
<listitem
><para
>Caixas</para
></listitem>
</itemizedlist
>
<para
>As linhas de texto são úteis para adicionar algumas informações textuais breves para um diagrama. Correspondem a texto livre e não têm nenhum significado para o modelo em si. </para
>
<para
>As notas são úteis para adicionar informações mais detalhada sobre um objecto ou uma dada situação. Têm a grande vantagem de poderem ser anexadas a Elementos de &UML; para mostrar que a nota <quote
>pertence</quote
> a um dado objecto ou situação. </para>
<para
>As caixas são rectângulos livres que poderão ser usados para agrupar os itens em conjunto para tornar os diagramas mais legíveis. Elas não têm significado lógico no modelo.</para>
<!-- FIXME, screenshot -->
</sect2
> <!-- helper elements -->
<sect2 id="component-diagram">
<title
>Diagramas de Componentes</title>
<para
>Os Diagramas de Componentes mostram os componentes do 'software' (sejam referentes a tecnologias de componentes como os KParts, os componentes do CORBA ou Java Beans, ou mesmo secções do sistema que sejam claramente distintas), bem como os artefactos de que são compostos, como os ficheiros de código-fonte, as bibliotecas de programação ou as tabelas de bases de dados relacionais.</para>
<para
>Os componentes poderão ter interfaces (&ie; classes abstractas com operações) quer permitem associar os componentes.</para>
</sect2>
<sect2 id="deployment-diagram">
<title
>Diagramas de Entrada em Produção</title>
<para
>Os Diagramas de Entrada em Produção mostram as instâncias em execução, bem como as suas associações. Eles incluem os Nós, que são recursos físicos, correspondendo tipicamente a um único computador. Mostram também as interfaces e os objectos (as instâncias das classes).</para>
</sect2>
</sect1
>
</chapter>
|