Documentos de Académico
Documentos de Profesional
Documentos de Cultura
Manual de UML
Manual de UML
-*
Universidad Nacional de
La Rioja
Carrera: Lic.
en Anlisis de Sistemas
Materia: Base
Docente:
de Datos
Curso: 4
Ao
Trabajo Prctico:
Integrantes:
Agero Jorge
Cornejo Anabella
Heredia Ana Gabriela
Pascal Alejandro
Noviembre de 2002
Indice
INTRODUCCIN.......................................................................................................................................................................4
UML (UNIFIED MODELING LANGUAGE)..........................................................................................................................5
DIFERENTES DEFINICIONES DE UML..............................................................................................................................5
BREVE RESEA HISTRICA................................................................................................................................................6
CARACTERSTICAS DE UML................................................................................................................................................7
OBJETIVOS................................................................................................................................................................................7
MODELO: NOCIONES GENERALES....................................................................................................................................8
DIAGRAMAS: VISTAZO GENERAL.....................................................................................................................................9
CLASIFICACIN DE DIAGRAMAS..............................................................................................................................................10
DIAGRAMAS ESTTICOS..........................................................................................................................................................12
Diagrama de Clases............................................................................................................................................................12
Elementos......................................................................................................................................................................................... 12
Clase............................................................................................................................................................................................. 12
Atributos.................................................................................................................................................................................. 13
Identificadores.....................................................................................................................................................................15
Atributos Derivados............................................................................................................................................................. 15
Restricciones de Atributos...................................................................................................................................................16
Mtodos................................................................................................................................................................................... 17
Relaciones entre Clases................................................................................................................................................................ 18
Herencia (Especializacin/Generalizacin)..............................................................................................................................19
Asociacin............................................................................................................................................................................... 22
Grado de la Asociacin........................................................................................................................................................23
Asociaciones Reflexivas......................................................................................................................................................23
Atributos de Liga (o Asociacin).........................................................................................................................................24
Ensamblados: Agregacin y Composicin...............................................................................................................................25
Dependencia o Instanciacin (uso): .........................................................................................................................................27
Diagrama de objetos...........................................................................................................................................................30
Diagrama.......................................................................................................................................................................................... 30
Diagrama de Componentes.................................................................................................................................................34
Diagramas de Implementacin...........................................................................................................................................35
DIAGRAMAS DINMICOS..........................................................................................................................................................36
Diagrama de Casos de Usos...............................................................................................................................................36
Elementos......................................................................................................................................................................................... 36
Actor............................................................................................................................................................................................ 36
Caso de Uso.................................................................................................................................................................................. 36
Relaciones.................................................................................................................................................................................... 36
Asociacin............................................................................................................................................................................... 36
Dependencia o Instanciacin....................................................................................................................................................37
Generalizacin......................................................................................................................................................................... 37
Diagrama de Secuencia......................................................................................................................................................38
Elementos......................................................................................................................................................................................... 38
Lnea de vida................................................................................................................................................................................ 38
Activacin.................................................................................................................................................................................... 38
Mensajes....................................................................................................................................................................................... 38
Diagrama de Colaboracin................................................................................................................................................40
Elementos......................................................................................................................................................................................... 40
Objeto........................................................................................................................................................................................... 40
Enlace........................................................................................................................................................................................... 40
Flujo de mensajes......................................................................................................................................................................... 40
Diagrama de actividad........................................................................................................................................................41
Diagrama de estado............................................................................................................................................................41
HERRAMIENTAS CASE QUE SOPORTA UML.................................................................................................................42
Introduccin
El presente trabajo surge por asignacin del profesor de la ctedra de Bases de Datos, de la carrera
de Lic. en Anlisis de Sistemas, Ing. Emilio Rearte. El tema asignado por el docente fue: Bases de
Datos y UML, adems tambin se asignaron a otros grupos temas tales como Modelos de Bases de
Datos en red, jerrquico, relacional y orientadas o objetos; Data Warehouse; y Bases de Datos en
Internet.
Dando una breve introduccin al tema; se puede decir que UML no es una metodologa, si no ms
bien es un lenguaje (pero no de programacin), una notacin, que permite visualizar, especificar,
construir y documentar el modelado de sistemas; sea cual fuere el ciclo de vida elegido para el anlisis,
diseo e implementacin del mismo. UML es de reciente aparicin y, al ser no propietario, es usado y
refinado por muchas empresas, grupos de investigadores y desarrolladores a nivel mundial.
Los temas tratados, ms adelante sern:
Unified Modeling Language (UML).
Breve resea histrica.
Caractersticas de UML.
Objetivos.
Modelos: nociones generales.
Diagramas: vistazo general.
Clasificacin de diagramas.
Diagramas estructurales:
- Diagrama de clases.
- Diagrama de objetos.
- Diagrama de componentes.
- Diagrama de implementacin.
- Diagramas dinmicos:
- Diagrama de casos de uso.
- Diagrama de secuencia.
- Diagrama de colaboracin
- Diagrama de actividad.
- Diagrama de estado.
- Herramientas CASE que soportan UML.
- Implementacin de Sistemas modelados en UML.
Lo que se pretende con este trabajo es dar a conocer lo que es UML, las distintas herramientas que
proporciona para el modelado de sistemas, y cmo lograr la implementacin de los mismos.
A continuacin, se desarrollarn los temas que forman parte del trabajo, los mismos ya fueron
mencionados.
CARACTERSTICAS DE UML
UML se quiere convertir en un lenguaje estndar con el que sea posible modelar todos los
componentes del proceso de desarrollo de aplicaciones. Sin embargo, hay que tener en cuenta un
aspecto importante del modelo: no pretende definir un modelo estndar de desarrollo, sino
nicamente un lenguaje de modelado. Otros mtodos de modelaje como OMT (Object Modeling
Technique) o Booch s definen procesos concretos. En UML los procesos de desarrollo son
diferentes segn los distintos dominios de trabajo; no puede ser el mismo el proceso para crear
una aplicacin en tiempo real, que el proceso de desarrollo de una aplicacin orientada a gestin,
por poner un ejemplo.
El mtodo del UML recomienda utilizar los procesos que otras metodologas tienen definidos.
OBJETIVOS
Como objetivos principales de la consecucin de un nuevo mtodo que aunara los mejores
aspectos de sus predecesores, sus protagonistas se propusieron lo siguiente:
El mtodo deba ser capaz de modelar no slo sistemas de software sino otro tipo de
sistemas reales de la empresa, siempre utilizando los conceptos de la orientacin a
objetos (OO).
Crear un lenguaje para modelado utilizable a la vez por mquinas y por personas.
Establecer un acoplamiento explcito de los conceptos y los artefactos ejecutables.
Manejar los problemas tpicos de los sistemas complejos de misin crtica.
Lo que se intenta es lograr con esto que los lenguajes que se aplican siguiendo los mtodos ms
utilizados sigan evolucionando en conjunto y no por separado. Y adems, unificar las perspectivas
entre diferentes tipos de sistemas (no slo software, sino tambin en el mbito de los negocios), al
aclarar las fases de desarrollo, los requerimientos de anlisis, el diseo, la implementacin y los
conceptos internos de la OO.
Clasificacin de Diagramas
Se dispone de dos tipos diferentes de diagramas los que dan una vista esttica del sistema y los
que dan una visin dinmica.
Diagramas estticos
o Estructurales
1. Diagramas de clase
2. Diagramas de objeto
3. Diagramas de componentes
4. Diagramas de implementacin
Diagramas dinmicos
o de Comportamiento
1. Diagrama de secuencia
2. Diagrama de colaboracin
3. Diagrama de estado
4. Diagrama de actividad
5. Diagrama de casos de uso
La practica de crear diagramas para visualizar sistemas desde perspectivas o vistas diferentes no
est limitado a la industria de la construccin. En el contexto del software, existen cinco vistas
complementarias que son las ms importantes para visualizar, especificar, construir y documentar la
arquitectura del software. En el UML las vistas existentes son:
1. Vista casos de uso: se forma con los diagramas de casos de uso, colaboracin, estados
actividades.
2. Vista de diseo: se forma con los diagramas de clases, objetos, colaboracin, estados
actividades.
3. Vista de procesos: se forma con los diagramas de la vista de diseo. Recalcando las clases
objetos referentes a procesos.
4. Vista de implementacin: se forma con los diagramas de componentes, colaboracin, estados
actividades.
5. Vista de despliegue: se forma con los diagramas de despliegue, interaccin, estados
actividades.
y
y
y
y
y
Como podemos ver el nmero de diagramas es muy alto, en la mayora de los casos excesivos, y
UML permite definir solo los necesarios, ya que no todos son necesarios en todos los proyectos
UML esta pensado para el modelado tanto de pequeos sistemas como de sistemas complejos, y
debemos tener en cuenta que los sistemas complejos pueden estar compuestos por millones de lneas
de cdigo y ser realizados por equipos de centenares de programadores.
En la prctica todos los diagramas son bidimensionales, pero el UML permite crear diagramas en
tres dimensiones como en modelos donde se puede "entrar" al modelo para poderlo visualizar por
dentro.
Con UML nos debemos olvidar del protagonismo excesivo que se le da al diagrama de clases, este
representa una parte importante del sistema, pero solo representa una vista esttica, es decir muestra
al sistema parado. Sabemos su estructura pero no sabemos que le sucede a sus diferentes partes
cuando el sistema empieza a funcionar.
Diagramas Estticos
Diagrama de Clases
En el diagrama de clases como ya hemos comentado ser donde definiremos las caractersticas de
cada una de las clases y relaciones de dependencia y generalizacin. Es decir, es donde daremos
rienda suelta a nuestros conocimientos de diseo orientado a objetos, definiendo las clases e
implementando las ya tpicas relaciones de herencia y agregacin.
Este diagrama sirve para visualizar las relaciones entre las clases que involucran el sistema, las
cuales pueden ser asociativas, de herencia, de uso y de contenido.
Se utiliza cuando necesitamos realizar un Anlisis de Dominio: El analista se entrevista con el
cliente con el objetivo de conocer las entidades principales en el dominio del cliente. Durante la
conversacin entre el cliente y el analista se deben tomar apuntes. Desde estos apuntes, se buscarn
las clases para los objetos del modelo buscando los sustantivos (ej: proveedor, pedido, factura, etc.) y
convirtindolos en clases. Despus se ver que algunos de estos sustantivos pueden ser atributos de
otros en vez de entidades por si mismas. Tambin se buscarn los mtodos para estas clases
buscando los verbos (ej: Calcular, imprimir, Agregar,..)
Elementos
Un diagrama de clases esta compuesto por los siguientes elementos:
Clase
Es la unidad bsica que encapsula toda la informacin de un Objeto (un objeto es una instancia de
una clase). A travs de ella podemos modelar el entorno en estudio (una Casa, un Auto, una Cuenta
Corriente, etc.).
En UML, una clase es representada por un rectngulo que posee tres divisiones:
En donde:
Superior: Contiene el nombre de la Clase
Intermedio: Contiene los atributos (o variables de instancia) que caracterizan a la Clase
(pueden ser private, protected o public).
Inferior: Contiene los mtodos u operaciones, los cuales son la forma como interacta el objeto
con su entorno (dependiendo de la visibilidad: private, protected o public).
Ejemplo:
Atributos
Un atributo representa alguna propiedad de la clase que se encuentra en todas las instancias de la
clase. Los atributos pueden representarse solo mostrando su nombre, mostrando su nombre y su tipo,
e incluso su valor por defecto.
Los atributos o caractersticas de una Clase pueden ser de tres tipos, los que definen el grado de
comunicacin y visibilidad de ellos con el entorno, estos son:
public
: Indica que el atributo ser visible tanto dentro como fuera de
la clase, es decir, es accesible desde todos lados.
Ejemplo: el valor del atributo edad puede ser "24" para los objetos Juan Prez y Mara Lpez, y
"15" para Ramn Martnez.
Dentro de una clase, los nombre de los atributos deben ser nicos (aunque puede aparecer el
mismo nombre de atributo en diferentes clases).
Ejemplo: Las clases persona y compaa pueden tener ambas un atributo direccin, en cambio no
pueden existir dos atributos llamados direccin dentro de la clase persona.
Los atributos no tienen ninguna identidad, al contrario de los objetos.
Ejemplo: Los atributos nombre y edad de la clase persona tienen valores simples. El valor para
nombre puede ser "Juan" o "Mara", mientras que el valor para edad puede ser "17" o "25". (Ntese
que pudieran existir dos objetos distintos con exactamente el mismo nombre y edad, donde estos
identificaran dos personas distintas.)
Un atributo como se ha definido en esta seccin se conoce tambin como atributo bsico.
Notacin extendida
Identificadores
En el momento de incluir atributos en la descripcin de una clase se debe distinguir entre los
atributos los cuales reflejan las caractersticas de los objetos en el mundo real, y los identificadores los
cuales son utilizados exclusivamente por razones de implementacin. Estos identificadores internos del
sistema no deben ser incluidos como atributos.
Ejemplo: Nmero del Seguro Social, o nmero de la licencia de conducir, son identificadores
vlidos del mundo real, en cambio un identificador para distinguir entre objetos de tipo persona no se
debe incluir en el diagrama. En la siguiente figura se muestra la forma incorrecta de incluir un
identificador (identificador : ID) en la clase del objeto, seguido por la forma correcta (omitido).
Atributos Derivados
Los atributos bsicos son atributos independientes dentro del objeto. En contraste, los atributos
derivados son atributos que dependen de otros atributos. Los atributos derivados dependen de otros
atributos del objeto, los cuales pueden ser bsicos o derivados. La notacin es una diagonal como
prefijo del atributo, como se muestra en la siguiente figura:
Ejemplo: El Area de un Rectngulo se puede calcular conociendo su Ancho y Largo, por lo cual no
se define como una atributo bsico de la caja, sino como un atributo derivado:
Restricciones de Atributos
Los valores de los atributos de una clase pueden restringirse. La notacin para una restriccin es
incluir, por debajo de la clase y entre corchetes, la restriccin para los valores del atributo, como se
muestra en la siguiente figura
Ejemplo: Un Rectngulo puede restringir que su Ancho y Largo sean siempre iguales, lo que es
equivalente a un Cuadrado. As mismo, el Area del Rectngulo est definida como el Ancho por el
Largo. Las dos restricciones se muestran a continuacin:
Mtodos
Un mtodo u operacin es la implementacin de un servicio de la clase, que muestra un
comportamiento comn a todos los objetos. En resumen es una funcin que le indica a las instancias
de la clase que hagan algo.
Las operaciones son funciones o transformaciones que se aplican a todos los objetos de una clase
particular. La operacin puede ser una accin ejecutada por el objeto o sobre el objeto.
Ejemplo: Arrojar, atrapar, inflar, y patear, son operaciones para la clase pelota. Abrir, cerrar, ocultar,
y dibujar, son operaciones para la clase ventana.
Las operaciones deben ser nicas dentro de una misma clases, aunque no necesariamente para
diferentes clases.
Ejemplo: Las clases pelota y libro pueden las dos tener operaciones de comprar, pero no pueden
tener cada una dos operaciones comprar.
No se debe utilizar el mismo nombre para operaciones que tengan un significado totalmente
diferente.
Ejemplo: No se debe utilizar el mismo nombre invertir para la operacin de invertir una figura y
para la operacin de invertir una matriz, ya que son operaciones totalmente diferentes. Invertir una
figura es rotarla por 180 grados, mientras que invertir una matriz M es encontrar su inverso N, para que
MxN = 1. Se deben usar nombres diferentes, como invertir-figura e invertir-matriz.
Las operaciones pueden tener argumentos, o sea, una lista de parmetros, cada uno con un tipo,
y pueden tambin devolver resultados, cada uno con un tipo.
Ejemplo: En la siguiente figura se muestra dos clases, Figura y Archivo, conteniendo atributos y
operaciones. Mover y Rotar son operaciones de Figura conteniendo los argumentos V de tipo vector y
Angulo, respectivamente. Ambas operaciones devuelven un resultado de tipo Booleano el cual
devuelve un valor de Cierto o Falso (True o False).
Imprimir es una operacin de Archivo conteniendo un argumento D de tipo dispositivo que puede
ser el nombre de una impresora, y el nmero N de copias a imprimir. El resultado puede ser un valor
booleano.
Los mtodos u operaciones de una clase son la forma en como sta interacta con su entorno,
stos pueden tener las caractersticas:
public
: Indica que el mtodo ser visible tanto dentro como fuera de la clase,
es decir, es accsesible desde todos lados.
private
: Indica que el mtodo slo ser accesible desde dentro de la clase
(slo otros mtodos de la clase lo pueden accesar).
protected
: Indica que el mtodo no ser accesible desde fuera de la clase,
pero si podr ser accesado por mtodos de la clase adems de mtodos de las
subclases que se deriven (ver herencia).
uno-uno
uno-muchos(1...*)
muchos-muchos(* *)
opcional (0..1 )
nmero fijo: m (m denota el nmero).
La notacin para representar una relacin opcional, donde la multiplicidad es "uno" o "cero",
escribiendo una relacin opcional, 0 o 1. Esto significa que dos objetos pueden o no estar conectados,
y si lo estn corresponden a una multiplicidad de 1.
Herencia (Especializacin/Generalizacin)
Las clases con atributos y operaciones comunes se pueden organizar de forma jerrquica,
mediante la herencia. La herencia es una abstraccin importante para compartir similitudes entre
clases, donde todos los atributos y operaciones comunes a varias clases se pueden compartir por
medio de la superclase, una clase ms general. Las clases ms refinadas se conocen como las
subclases.
Ejemplo: Las Impresoras Lser, de Burbuja, y de Matriz, son todas subclases de la superclase
Impresora. Los atributos generales de una Impresora son el Modelo, Velocidad, y Resolucin, mientras
que sus operaciones son Imprimir y Alimentar.
La Herencia es til para el modelo conceptual al igual que para la implementacin. Como modelo
conceptual da buena estructuracin a las clases. Como modelo de implementacin es un buen
vehculo para no replicar innecesariamente el cdigo. Generalizacin define una relacin entre una
clase ms generalizada, y una o ms versiones refinadas de ella.
Ejemplo: La clase Impresora es una generalizacin de las clases Impresoras Lser, de Burbuja, y
de Matriz.
Especializacin define una relacin entre una clase ms general, y una o ms versiones
especializadas de ella.
Ejemplo: Impresoras Lser, de Burbuja, y de Matriz, son todas especializaciones de Impresoras.
La superclase generaliza a sus subclases, y las subclases especializan a la superclase. El proceso
de especializacin es el inverso de generalizacin. Una instancia de una subclase, o sea un objeto, es
tambin una instancia de su superclase.
Ejemplo: Cuando se crea un objeto de tipo Impresora Lser, este objeto incluye toda la
informacin descrita en la subclase Impresora Lser, al igual que en la superclase Impresora; por lo
tanto se considera que el objeto es una instancia de ambas.
La herencia es transitiva a travs de un nmero arbitrario de niveles. Los ancestros de una clase
son las superclases de una clase en cualquier nivel superior de la jerarqua, y los descendientes de
una clase son las subclases de una clase en cualquier nivel inferior de la jerarqua.
Ejemplo: Si adems de Impresora de Burbuja, se define una clase ms especializada como
Impresora de Burbuja Porttil, entonces Impresora e Impresora de Burbuja son ancestros de la clase
Impresora de Burbuja Porttil, mientras que Impresora de Burbuja e Impresora de Burbuja Porttil son
descendientes de Impresora.
La herencia indica que una subclase hereda los mtodos y atributos especificados por una Super
Clase, por ende la Subclase adems de poseer sus propios mtodos y atributos, poseer las
caractersticas y atributos visibles de la Super Clase (public y protected), ejemplo:
En la figura se especifica que Auto y Camioneta heredan de Vehculo, es decir, Auto posee las
Caractersticas de Vehculo (Precio, VelMax, etc) adems posee algo particular que es Descapotable,
en cambio Camioneta tambin hereda las caractersticas de Vehculo (Precio, VelMax, etc) pero posee
como particularidad propia Tara y Carga.
Cabe destacar que fuera de este entorno, lo nico "visible" es el mtodo Caractersticas aplicable
a instancias de Vehculo, Auto y Camioneta, pues tiene definicin publica, en cambio atributos como
Descapotable no son visibles por ser privados.
(Los nombres de atributos y operaciones deben ser nicos en la jerarqua de herencia.)
Ejemplo: Una Impresora de Burbuja Porttil incorpora todas las caractersticas, primero de una
Impresora, y luego de una Impresora de Burbuja, conteniendo valores para todos los atributos
ancestrales y pudindose aplicar todas las operaciones ancestrales.
La generalizacin se puede extender a mltiples niveles de jerarquas, donde una clase hereda de
su superclase, que a su vez hereda de otra superclase, hacia arriba en la jerarqua. En otras palabras,
las relaciones entre subclases y superclases son relativas. La herencia define una jerarqua de clases
donde existen ancestros y descendientes, que pueden ser directos o no.
Ejemplo: Un Barco tiene un Nombre, Fabricante, y Costo. Tipos especiales de Barco, como Velero,
tienen adems de estas caractersticas bsicas, un Nmero de Velas, mientras que otro tipo especial
de Barco, como Barco a Motor, tiene un Motor. Barco es la clase bsica (la superclase) mientras que
Velero y Barco a Motor son las clases refinadas (las subclases). Se debe definir las caractersticas
bsicas de los barcos una sola vez, y luego aadir detalles para veleros, barcos a motor, etc.
Diagrama de clases describiendo diferentes tipos de Mueble, Asiento y Mesa, con sus
respectivas subclases.
Ejemplo: Una jerarqua conteniendo una superclase Mueble, y varias subclases Mesa y Asiento,
puede ser extendida con nuevas subclases, como Mesa Circular, Mesa Rectangular, mientras que un
Asiento puede extenderse con las subclases Silla, Silln, y Taburete.
Cada clase tiene sus propios atributos los cuales se van especializando a medida que las clases
son cada vez ms especializadas. Ntese que no necesariamente todas las clases tienen que incluir
atributos.
Asociacin
La relacin entre clases conocida como Asociacin, permite asociar objetos que colaboran entre
si.
Una asociacin describe la relacin entre clases de objetos, y describe posibles ligas, donde una
liga es una instancia de una asociacin, al igual que un objeto es una instancia de una clase.
Ejemplo:
Un cliente puede tener asociadas muchas Ordenes de Compra, en cambio una orden de compra
solo puede tener asociado un cliente.
Grado de la Asociacin
El grado de una asociacin se determina por el nmero de clases conectadas por la misma
asociacin. Las asociaciones pueden ser binarias, ternarias, o de mayor grado. Las asociaciones se
consideran binarias si relacionan solo dos clases.
Ejemplo: La asociacin entre Persona e Instituto es una asociacin binaria.
Las asociaciones pueden ser de mayor grado si relacionan a la misma vez ms de dos clases.
Aparte de relaciones binarias, lo ms comn son relaciones ternarias (entre tres clases), relaciones de
ms alto nivel son mucho menos comunes. Mientras el grado de una relacin aumenta, su
comprensin se dificulta, y se debe considerar partir las relaciones en varias relaciones binarias.
Ejemplo: Puede existir una relacin ternaria entre Estudiante, Profesor, y Universidad donde "un
estudiante estudia con un profesor en una universidad".
El grado de las ligas corresponden al de las asociaciones.
Asociaciones Reflexivas
Las asociaciones pueden ser reflexivas, relacionando distintos objetos de una misma clase.
Ejemplo: Para una clase persona puede existir una asociacin pariente que describe que dos
objetos de tipo persona, como Juan Prez y Laura Prez son parientes.
El grado de una asociacin reflexiva puede ser binario, ternario, o de mayor grado, dependiendo
del nmero de objetos involucrados.
Ejemplo: Para la clase persona puede existir una asociacin ternaria entre tres personas donde
uno es el abuelo, el otro es el hijo del abuelo, y el tercero es el nieto del abuelo.
Las asociaciones reflexivas relacionan distintos objetos de una misma clase.
Ejemplo: Juan Prez es pariente-de Laura Prez, donde ambos son objetos de tipo Persona, como
se muestra en la Figura
Ejemplo: Para una asociacin entre Persona y Compaa, se puede definir los atributos salario y
puesto como atributos de la asociacin trabaja-para, como se muestra en la Figura de abajo:
Diagrama de clases para Persona y Compaa conteniendo los atributos de asociacin salario y puesto.
Diagrama de objetos para Ral Gonzlez e IBM conteniendo el valor de $100,000 para el
atributo de asociacin salario, y gerente para el atributo de liga puesto.
Agregacin:
(el objeto base utiliza al incluido para su funcionamiento). Es un tipo de relacin dinmica, en
donde el tiempo de vida del objeto incluido es independiente del que lo incluye.
Composicin:
(el Objeto base se construye a partir del objeto incluido). Es un tipo de relacin esttica, en
donde el tiempo de vida del objeto incluido esta condicionado por el tiempo de vida del que lo
incluye.
Un ensamblado puede componerse de varias partes, donde cada relacin se considera una
relacin separada. En el caso de agregacin, las partes del ensamblado pueden aparecer en mltiples
ensamblados. En el caso de composicin, las partes del ensamblado no pueden ser compartidas entre
ensamblados.
Ejemplo: Una Red de Computadoras se puede considerar un ensamblado, donde las
Computadoras son sus componentes. Este tambin es un ejemplo de agregacin, ya que las
Computadoras pudieran ser partes de mltiples Redes de Computadoras a la vez. Adicionalmente, las
Computadoras pueden existir independientemente de la existencia de la Red de Computadoras.
Ejemplo: Un Automvil se puede tambin considerar un ensamblado, donde el Motor y la
Carrocera son sus componentes. Este tambin es un ejemplo de composicin, ya que el Motor y la
Carrocera son partes del Automvil, y a diferencia de la agregacin, no pueden ser compartidos entre
distintos Automviles a la vez.
Adicionalmente, no tiene mucho sentido que el Motor y la Carrocera existan de manera
independiente al Automvil, por lo cual la composicin refleja de manera importante, el concepto de
propiedad.
El ensamblado tiene propiedades de transicin: Si A es parte de B y B es parte de C; entonces A
es parte de C.
Ejemplo: Si el Motor es parte del Automvil, entonces sus propiedades, como su posicin y
velocidad, estn dadas por la posicin y velocidad del Automvil.
El ensamblado es antisimtrico: Si A es parte de B, entonces B no es parte de A. Estas
propiedades se propagan entre el ensamblado y sus componentes.
Ejemplo: Si el Motor es parte del Automvil, entonces el Automvil no es parte del Motor.
Se considera un ensamblado y no una asociacin regular:
Si se puede usar la frase "parte-de" o "consiste-de" o "tiene";
Si algunas operaciones en el todo se pueden propagarse a sus partes;
Si algunos atributos en el todo se pueden propagar a sus partes;
El ensamblado es comn en los objetos interfaz. En un sistema de ventanas, por ejemplo, una
ventana puede consistir de botones, mens, y barras (scrollbars), cada una modelada por su propio
objeto interfaz. El resultado es una estructura de interfaz en forma de rbol. La decisin de usar
ensamblados es un poco arbitraria, y en la prctica no causa grandes problemas la distincin imprecisa
entre agregacin, composicin y asociacin, aunque es bueno ser consistente.
Ejemplo: Una computadora personal (PC) est compuesta por uno o varios monitores, un sistema, un
teclado y opcionalmente un ratn. El sistema tiene un chasis, un procesador central (CPU), varias
tarjetas de memoria (RAM), y opcionalmente un ventilador. El diagrama se muestra en la siguiente
figura
Otro Ejemplo:
Cabe destacar que el objeto creado (en este caso la Ventana grfica) no se almacena dentro del
objeto que lo crea (en este caso la Aplicacin).
Ejemplo: La clase Persona tiene un Nombre, Direccin, y Nmero del Seguro Social. Una persona
puede trabajar en algn proyecto y ganar un salario. Una Compaa tiene un Nombre, Direccin,
Nmero de Telfono, y Producto Primario. Una Compaa contrata y despide Personas. Persona y
Compaa tienen una relacin "muchos-muchos".
El ttulo del trabajo depende de la persona y de la compaa. Hay dos tipos de Personas: Trabajadores
y Administradores. Cada Trabajador est involucrado en varios Proyectos; cada Administrador es
responsable de varios proyectos. En un proyecto pueden trabajar varios trabajadores y un solo
administrador. Cada proyecto tiene un Nombre, Presupuesto, y una Prioridad Interna para asegurar
recursos. Adems una Compaa est compuesta de mltiples Departamentos; cada departamento
dentro de una compaa se identifica de forma nica por su Nombre.
Un departamento usualmente tiene un administrador. La mayora de los administradores manejan un
departamento; y algunos administradores no estn asignados a ningn departamento. Cada
departamento manufactura varios productos; mientras que cada producto est hecho por un solo
departamento. Un producto tiene Nombre, Costo, y Peso.
El diagrama es el siguiente:
Diagrama de objetos
Pertenece a la clasificacin de los diagramas que dan una vista esttica del sistema.
Contiene un conjunto de instancias de los elementos encontrados en un Diagrama de Clases. Por
lo tanto, expresa la parte esttica de una interaccin, consistiendo en los objetos que colaboran, pero
son ninguno de los mensajes enviados entre ellos.
Para realizarlo primero se debe decidir que situacin queremos representar del sistema, en un
momento concreto del mismo, permitiendo as mostrar los objetos y sus relaciones
En los diagramas de objetos tambin se pueden incorporar clases, para mostrar la clase de la que
es un objeto representado.
Con los Diagrama de Objetos no se puede especificar completamente la estructura de objetos del
sistema. Puede existir una multitud de posibles instancias de una clase particular, y para un conjunto
de clases con relaciones entre ellas, pueden existir muchas ms configuraciones posibles de esos
objetos.
Diagrama
Al momento de construir el Diagrama de Objetos hay que tener bien en claro dos concepto muy
importantes.
En primer lugar saber a que nos referimos cuando hablamos de objeto.
Los objetos son las entidades bsicas del modelo de objeto. La palabra objeto proviene del latn
objectus, donde ob significa hacia, y jacere significa arrojar; o sea, que tericamente un objeto es
cualquier cosa que se pueda arrojar.
Ejemplo: Una pelota o un libro se pueden arrojar, por lo tanto estos son objetos. Por otro lado, un
avin o un elefante tambin se consideran objetos, aunque sean bastante pesados para ser arrojados.
Los objetos son ms que simples cosas que se puedan arrojar, son conceptos, pudiendo ser
abstractos o concretos.
Ejemplo: Una mesa es un objeto concreto, mientras que un viaje es un objeto abstracto.
Los objetos corresponden por lo general a sustantivos, pero no a gerundios.
Ejemplo: Mesa y viaje son ambos sustantivos y por lo tanto objetos. Trabajando y estudiando son
gerundios por lo cual no se consideran objetos.
Cualquier cosa que incorpore una estructura y un comportamiento se le puede considerar como un
objeto.
Ejemplo: Una pelota es slida y redonda y se le puede arrojar o atrapar. Un libro es rectangular y
slido y se le puede abrir, cerrar, y leer.
Un objeto debe tener una identidad coherente, al que se le puede asignar un nombre razonable y
conciso.
Ejemplo: Se consideran manzanas todas las frutas con un sabor, textura, y forma similar.
La existencia de un objeto depende del contexto del problema. Lo que puede ser un objeto
apropiado en una aplicacin puede no ser apropiado en otra, y al revs. Por lo general, existen muchos
objetos en una aplicacin, y parte del desafo es encontrarlos.
Ejemplo: La temperatura se puede considerar un objeto abstracto, teniendo propiedades tales
como el valor de la temperatura y el tipo de la escala en que se mide (Celsius o Fahrenheit). Por otro
lado, si hablamos de un termmetro, la temperatura pasa a ser una propiedad del termmetro.
Los objetos se definen segn el contexto de la aplicacin.
Ejemplo: Una persona llamada Juan Prez se considera un objeto para una compaa, mientras
que para un laboratorio el hgado de Juan Prez es un objeto. Una universidad como la UNLaR se
considera un objeto, mientras que dentro de la UNLaR los objetos seran las aulas, los estudiantes y
los profesores.
Los objetos deben ser entidades que existen de forma independiente. Se debe distinguir entre los
objetos, los cuales contienen caractersticas o propiedades, y las propias caractersticas.
Ejemplo: El color y la forma de una manzana no se consideran propiamente objetos, sino
propiedades del objeto manzana. El nombre de una persona se considera una propiedad de la
persona.
Un grupo de cosas puede ser un objeto si existe como una entidad independiente.
Ejemplo: Un automvil se considera un objeto el cual consiste de varias partes, como el motor y la
carrocera.
Los objetos deben tener nombres en singular, y no en plural.
Ejemplo: Un automvil es un objeto, automviles son simplemente muchos objetos y no un solo
objeto.
Parte de una cosa puede considerarse un objeto.
Ejemplo: La rueda, la cual es parte del automvil, se puede considerar un objeto. Por otro lado, el
lado izquierdo del automvil sera un mal objeto.
Los objetos deben tener nombren razonables y concisos para evitar la construccin de objetos que
no tengan una identidad coherente.
Ejemplo: Datos o informacin no son nombres concisos de objetos. Por otro lado, un estudiante
es un objeto, ya que contiene propiedades como el nmero de matrcula y nombre del estudiante,
adems incluye un comportamiento tal como ir a clases, presentar exmenes, y graduarse. Todos los
estudiantes cuyos apellidos comiencen con "A" sera un mal objeto ya que el nombre del objeto no es
conciso.
El objeto integra una estructura de datos (atributos) y un comportamiento (operaciones).
Y segundo lugar, el termino identidad; aclarado a continuacin.
Los objetos se distinguen por su propia existencia, su identidad, aunque internamente los valores
para todos sus datos sean iguales. Todos los objetos se consideran diferentes.
Ejemplo: Si tenemos una biblioteca llena de libros, cada uno de esos libros, como La Ilada,
Hamlet, La Casa de los Espritus, etc., se consideran e identifican como objetos diferentes. Dos
manzanas aunque sean exactamente del mismo color y forma, son diferentes objetos.
Nombre del
objeto
Notacin para un objeto
objeto.
UNLaR
Como se menciono al principio de esta seccin el Diagrama de Objetos representa a los objetos y
sus relaciones. La pregunta ahora seria de qu manera?. A continuacin se detalla los pasos a seguir
para construir un Diagrama de Objetos
Hay que identificar el mecanismo que se desea modelar. Un mecanismo representa alguna funcin
o comportamiento de la parte del sistema que se est modelando, que resulta de la interaccin de una
sociedad de clases, interfaces y otros elementos.
Para cada mecanismo hay que identificar las clases, interfaces y otros elementos que participan
en esta colaboracin; identificar tambin las relaciones entre estos elementos.
Hay que considerar un escenario en el que intervenga este mecanismo. Tambin hay que congelar
este escenario en un momento concreto, y representar cada objeto que participo en el mecanismo.
Hay que mostrar el estado y valores de los atributos de cada uno de esos objetos si son
necesarios para comprender el escenario.
Anlogamente hay que mostrar los enlaces entre esos objetos, que representan instancias de
asociaciones entre ellos.
Por ejemplo, en la siguiente figura se representa un conjunto de objetos extrados de la
implementacin de un robot autnomo. Esta figura se centra en algunos de los objetos implicados en el
mecanismo utilizado por el robot para calcular un modelo del mundo en el que se mueve. Hay muchos
ms objetos implicados en un sistema en ejecucin, pero este diagrama se centra slo en aquellas
abstracciones implicadas directamente en la creacin de esta vista del mundo.
m:Mundo
a1:Area
p1:ParedAnch
ura = 36
<<global>>
sinAsignar
:Elemento
a2:Area
p1:ParedAnch
ura = 96
d8:PuertaAnc
hura = 36
p1:ParedAnch
ura = 96
Como indica la figura, un objeto representa al propio robot (r, una instancia de Robot), y r se
encuentra actualmente en el estado movimiento. Este objeto tiene un enlace con m, una instancia de
Mundo, que representa una abstraccin del modelo del mundo del robot. Este objeto tiene un enlace
con un multiobjeto que consiste en instancias de Elemento, que representa entidades que el robot ha
identificado, pero an no ha asignado en su vista del mundo. Estos elementos se marcan como parte
del estado global del robot.
En ese instante, m est enlazado a dos instancias de Area. Una de ellas (a2) se muestra con sus
propios enlaces a tres objetos Pared y un objeto Puerta. Cada una de estas paredes est etiquetada
con su anchura actual, y cada una se muestra enlazada a sus paredes vecinas. Como sugiere este
diagrama de objetos, el robot ha reconocido el rea que lo contiene, que tiene paredes en tres lados y
una puerta en el cuarto.
Diagrama de Componentes
Un diagrama de componentes muestra las organizaciones y dependencias lgicas entre
componentes software, sean stos componentes de cdigo fuente, binarios o ejecutables. Los
elementos de modelado dentro de un diagrama de componentes sern componentes y paquetes. En
cuanto a los componentes, slo aparecen tipos de componentes, ya que las instancias especficas de
cada tipo se encuentran en el diagrama de despliegue.
Cada componente en el diagrama debe ser documentado con un diagrama de componentes ms
detallado, un diagrama de clases, o un diagrama de casos de uso.
Un paquete en un diagrama de componentes representa una divisin fsica del sistema. Los
paquetes se organizan en una jerarqua de capas donde cada capa tiene una interfaz bien definida. Un
diagrama de componentes se representa como un grafo de componentes software unidos por medio
de relaciones de dependencia (generalmente de compilacin).
Normalmente los diagramas de componentes se utilizan para modelar cdigo fuente, versiones
ejecutables, bases de datos fsicas, entre otros.
Cdigo fuente: En el modelado de cdigo fuentes se suelen utilizar para representar las
dependencias entre los ficheros de cdigo fuente, o para modelar las diferentes versiones de estos
fichero. Para ello se deben identificar el conjunto de archivos de cdigo fuente de inters y
estereotiparlos como archivos file, agruparlos en paquetes, utilizar valores etiquetados para la
informacin de versiones y modelar las dependencias de compilacin.
Cdigo ejecutable: Se utiliza para modelar la distribucin de una nueva versin a los usuarios.
Para tal propsito se identifican el conjunto de componentes ejecutables que intervienen, se utilizan
estereotipos para los diferentes tipos de componentes (ejecutables, bibliotecas, tablas, archivos,
documentos, etc.), se consideran las relaciones entre dichos componentes que la mayora de las veces
incluirn interfaces que son exportadas (realizadas) por ciertos componentes e importadas (utilizadas)
por otros.
Bases de datos fsica: UML permite el modelado de bases de datos fsicas as como de los
esquemas lgicos de bases de datos.
As si tenemos en cuenta las dependencias asociadas al proceso de compilacin un componente
podra ser:
Cdigo fuente: que depende de otros componentes (no necesariamente cdigo fuente) que
deben estar disponibles durante la compilacin del componente.
Cdigo objeto binario: como por ejemplo una librera, que puede depender de algn cdigo
objeto con el que se linkea.
Cdigo ejecutable: que puede depender de otros programas ejecutables con los que
interaccionan en tiempo de ejecucin.
El Diagrama de Componentes se usa para modelar la estructura del software, incluyendo las
dependencias entre los componentes de software, los componentes de cdigo binario, y los
componentes ejecutables. En el Diagrama de Componentes se modela componentes del sistema, a
veces agrupados por paquetes, y las dependencias que existen entre componentes (y paquetes de
componentes).
Diagramas de Implementacin
Los Diagramas de Implementacin se usan para modelar la configuracin de los elementos de
procesado en tiempo de ejecucin (run-time processing elements) y de los componentes, procesos y
objetos de software que viven en ellos.
Los Diagramas de Implementacin se usan para modelar slo componentes que existen como
entidades en tiempo de ejecucin; no se usan para modelar componentes solo de tiempo de
compilacin o de tiempo de enlazado. Puedes tambin modelar componentes que migran de nodo a
nodo u objetos que migran de componente a componente usando una relacin de dependencia con el
estereotipo 'becomes' (se transforma)
Diagramas dinmicos
Diagrama de Casos de Usos
Se emplea para visualizar el comportamiento del sistema, una parte de l o de una sola clase; y
como se relaciona con su entorno. De sta forma se puede conocer como responde sa parte del
sistema ante un estmulo del ambiente. El diagrama de uso es muy til para definir como debera ser el
comportamiento de una parte del sistema, ya que solo especifica como deben comportarse y no como
estn implementadas las partes que define.
Un caso de uso especifica un requerimiento funcional.
Elementos
Un diagrama de casos de uso consta de los siguientes elementos:
Actor
Un actor es un rol que tiene un usuario con respecto al sistema. Es decir, sera un usuario del
sistema. Es importante destacar el uso de la palabra rol, ya que esto especifica que un actor no
necesariamente representa a una persona en particular, si no la labor que realiza frente al sistema.
Por ejemplo, en un sistema de ventas, el rol de Vendedor con respecto al sistema puede ser
realizado por un Vendedor o bien por el Jefe de Local.
Caso de Uso
Es una operacin o tarea especfica que se realiza tras una orden o estmulo de un agente
externo, puede ser un actor o desde la invocacin desde otro caso de uso.
Relaciones
Asociacin
Es el tipo de relacin ms bsica, indica la invocacin desde un actor o caso de uso a otra
operacin (caso de uso). Dicha relacin se denota con una flecha simple:
Dependencia o Instanciacin
Es una forma muy particular de relacin entre clases, en la cual una clase depende de otra, es
decir, se instancia (se crea). Dicha relacin se denota con una flecha punteada:
Generalizacin
Este tipo de relacin es una de las ms utilizadas, cumple una doble funcin dependiendo de
su estereotipo, que puede ser de Uso (<<uses>>) o de Herencia (<<extends>>).
Este tipo de relacin esta orientado exclusivamente para casos de uso.
extends: se recomienda utilizar cuando un caso de uso es similar a otro (en caractersticas).
uses: se recomienda utilizar cuando se tiene un conjunto de caractersticas que son similares
en ms de un caso de uso y no se desea mantener copiada la descripcin de la caracterstica.
Diagrama de Secuencia
Este diagrama (tambin llamado diagrama de interaccin) muestra las interacciones entre un
conjunto de objetos (clases, actores), ordenadas segn el tiempo en que tienen lugar. Es decir,
muestra el orden de las llamadas en el sistema. Se utiliza un diagrama para cada llamada a
representar. Es imposible representar en un solo diagrama la secuencia de todas las llamadas posibles
del sistema, es por ello que se escoge un punto de partida. El diagrama se compone con los objetos
que forman parte de la secuencia, estos se sitan en la parte superior de la pantalla, normalmente a la
izquierda se sita el que inicia la accin. De estos objetos sale una lnea que indica su vida en el
sistema. Esta lnea simple se convierte en una lnea gruesa cuando representa que el objeto tiene el
foco del sistema, es decir cuando l esta activo.
El objeto puede existir slo durante la ejecucin de la interaccin, se puede crear o puede ser
destruido durante la ejecucin de la interaccin.
En este tipo de diagramas tambin intervienen los mensajes, que son la forma en que se
comunican los objetos: el objeto origen solicita (llama a) una operacin del objeto destino. El diagrama
de secuencia puede ser obtenido de dos partes, desde el Diagrama Esttico de Clases o desde el de
Casos de Usos.
Elementos
Los componentes de un diagrama de interaccin son:
Lnea de vida
Un objeto (o actor) se representa como una lnea vertical punteada con un rectngulo de
encabezado y con rectngulos a travs de la lnea principal que denotan la ejecucin de mtodos
(activacin). El rectngulo de encabezado contiene el nombre del objeto y el de su clase.
Activacin
Muestra el periodo de tiempo en el cual el objeto se encuentra desarrollando alguna operacin,
bien sea por s mismo o por medio de delegacin a alguno de sus atributos. Se denota como un
rectngulo delgado sobre la lnea de vida del objeto.
Mensajes
El envo de mensajes entre objetos se denota mediante una lnea slida dirigida, desde el objeto
que emite el mensaje hacia el objeto que lo ejecuta. Representa la llamada de un mtodo
(operacin) de un objeto en particular.
El presente diagrama es til para observar la vida de los objetos en el sistema, identificar llamadas
a realizar o posibles errores del modelo esttico, que imposibiliten el flujo de informacin o de llamadas
entre los componentes del sistema.
Diagrama de Colaboracin
Este diagrama muestra la interaccin entre varios objetos y los enlaces que existen entre ellos.
Representa las interacciones entre objetos organizadas alrededor de los objetos y sus vinculaciones. A
diferencia de un diagrama de secuencias, un diagrama de colaboraciones muestra las relaciones entre
los objetos, no la secuencia en el tiempo en que se producen los mensajes. Los diagramas de
secuencias y los diagramas de colaboraciones expresan informacin similar, pero en una forma
diferente.
Elementos
Los elementos que intervienen en stos diagramas son: objetos, enlaces y flujos de mensajes.
Objeto
Un objeto se representa con un rectngulo, que contiene el nombre y la clase del objeto. Un objeto
es una instancia de una clase que participa como una interaccin, existen objetos simples y complejos.
Un objeto es activo si posee un thread o hilo de control y es capaz de iniciar la actividad de control,
mientras que un objeto es pasivo si mantiene datos pero no inicia la actividad.
Enlace
Un enlace es una instancia de una asociacin en un diagrama de clases. Se representa como una
lnea continua que une a dos objetos en este diagrama. Esta acompaada por un nmero que indica el
orden dentro de la interaccin y por un estereotipo que indica que tipo de objeto recibe el mensaje. El
enlace puede ser reflexivo si conecta a un elemento consigo mismo. La existencia de un enlace entre
dos objetos indica que puede existir un intercambio de mensajes entre los objetos conectados.
Flujo de mensajes
Expresa el envo de un mensaje. Se representa mediante una flecha dirigida cercana a un enlace.
Los mensajes que se envan entre objetos pueden ser de distintos tipos, tambin segn como se
producen en el tiempo; existen mensajes simples, sincrnicos, balking, timeout y asncronos.
Durante la ejecucin de un diagrama de colaboracin se crean y destruyen objetos y enlaces.
Diagrama de actividad
Son similares a los diagramas de flujos de otras metodologas OO. En realidad se corresponden
con un caso especial de los diagramas de estado donde los estados son estados de accin (estados
con una accin interna y una o ms transiciones que suceden al finalizar esta accin, o lo que es lo
mismo, un paso en la ejecucin de lo que ser un procedimiento) y las transiciones vienen provocadas
por la finalizacin de las acciones que tienen lugar en los estados de origen. Siempre van unidos a una
clase o a la implementacin de un caso de uso o de un mtodo (que tiene el mismo significado que en
cualquier otra metodologa OO). Los diagramas de actividad se utilizan para mostrar el flujo de
operaciones que se desencadenan en un procedimiento interno del sistema.
Diagrama de estado
Representan la secuencia de estados por los que un objeto o una interaccin entre objetos pasa
durante su tiempo de vida en respuesta a estmulos recibidos. Representa lo que podemos denominar
en conjunto una mquina de estados. Un estado en UML es cuando un objeto o una interaccin
satisface una condicin, desarrolla alguna accin o se encuentra esperando un evento.
Cuando un objeto o una interaccin pasa de un estado a otro por la ocurrencia de un estmulo o
evento se dice que ha sufrido una transicin, existen varios tipos de transiciones entre objetos: simples
(normales y reflexivas) y complejas. Adems una transicin puede ser interna si el estado del que parte
el objeto o interaccin es el mismo que al que llega, no se provoca un cambio de estado y se
representan dentro del estado, no de la transicin.
Rational Rose es la herramienta CASE que comercializan los desarrolladores de UML y que
soporta de forma completa la especificacin del UML.
Esta herramienta propone la utilizacin de cuatro tipos de modelo para realizar un diseo del
sistema, utilizando una vista esttica y otra dinmica de los modelos del sistema, uno lgico y otro
fsico. Permite crear y refinar estas vistas creando de esta forma un modelo completo que representa
el dominio del problema y el sistema de software.
Como podr observarse al comparar los dos esquemas anteriores, en el segundo, al estar ya en la
implementacin del sistema, aparecen identificadores que hacen nico a un objeto en un registro
fsico, y atributos que me permiten relacionar las tablas.
Recordemos un caso prestado cuando se hablo de la identidad de los objetos en la seccin Diagrama
de Objetos.
Los objetos se distinguen por su propia existencia, su identidad, aunque internamente los
valores para todos sus datos sean iguales. Todos los objetos se consideran diferentes.
Ejemplo: Si tenemos una biblioteca llena de libros, cada uno de esos libros, como La
Ilada, Hamlet, La Casa de los Espritus, etc., se consideran e identifican como objetos
diferentes. Dos manzanas aunque sean exactamente del mismo color y forma, son
diferentes objetos.
Esto no sucede en una Base de Datos fsica. Si los libros de una biblioteca no tienen un atributo
que los identifique unvocamente, sern vistos por la Base de Datos como un mismo objeto (libro), a
pesar de que el resto de sus atributos, conceptualmente, los muestre como objetos distintos.
Recurdese que las computadoras manejan 0 y 1, y es por esto, que no comprenden la diferencia
entre las caractersticas de los libros de la biblioteca que para nosotros (humanos) es tan simple
hacerlo, necesitando as un atributo que los identifique.
Conclusin
A nuestro parecer UML es la mejor solucin para todos los profesionales relacionados con
el Anlisis de Sistemas, ya que si nos tocara trabajar en un proyecto de software, en el cual
sabemos que el nmero de integrantes no es para nada reducido (si se trabajase en
empresas grandes), sin la aplicacin de UML, se hace engorroso ponerse de acuerdo en las
metodologas que se utilizarn, en las notaciones que se emplearn para cada modelo (ya
sea de anlisis o de implementacin). Es por ello que este nuevo paradigma de diseo nos
posibilita unificar todos nuestros criterios, para un posterior entendimiento, y mejor
organizacin de los proyectos.
Como desventaja podemos destacar (aunque para algunos o muchos no lo sera) que
UML permite especificar, visualizar y construir software's, pero orientado a objetos. Para
aquellos que prefieran las metodologas estructuradas debern esperar que surja un Lenguaje
Unificado de Modelado Estructurado.
Pensamos que esto no suceder, a lo sumo aparecer alguna extensin de UML para
considerar algn aspecto del modelo estructurado, pero a nuestro parecer no sera muy
justificable, por que a lo que se apunta en la actualidad es a la aplicacin de metodologas
orientadas a objetos, pues stas brindan muchas ventajas y solucionan muchos de los
problemas que surgen en las metodologas estructuradas.
Bibliografa
El lenguaje de unificado de modelado. de Grady Booch, James Rumbauch e Ivar Jacobson.
Edit:Addison Wesley. 1 edicin en espaol 1999
Modelos y diseos orientados a objetos - Metodologa OMT - . De James Rumbaugh, Michael Blaha,
William Premeralni, Frederick Hed y William Lorensen. Editorial: PRENTICE HALL. 1996.
Curso de Ingeniera del Sofware - Unidad 5.1 Diseo de Bases de Datos Relacionales y Conceptos de
la Orientacin a Objetos - . De J. Pedro Caraca, Valiente y Hernndez. ITBA (Instituto Tecnolgico de
Buenos Aires - Universidad Privada -). 1997.
Sitios Consultados
http://cavirtual.ing.ula.ve/JornadasVirtuales/XIIIJornadas/edu214/edu214.htm
http://lucas.hispalinux.es/Tutoriales/doc-modelado-sistemas-UML/multiple-html/index.html
http://sigma.poligran.edu.co/politecnico/apoyo/sistemas/inve/docs_012/uml_03/queesuml.htm
http://usuarios.lycos.es/oopere/uml.htm
http://www.creangel.com/uml/intro.html
http://www.cs.ualberta.ca/~pfiguero/soo/metod/uml-met.html
http://www.dcc.uchile.cl/~psalinas/uml/interaccion.html
http://www.docirs.cl/uml.htm
http://www.dte.us.es/personal/pruiz/investigacion/trabajo_investigacion/html/node22.html
http://www.embarcadero.com/support/what_is_uml.asp
http://www.mcc.unam.mx/~cursos/Objetos/Cap8/cap8.html
http://www.monografias.com/trabajos5/insof/insof.shtml
http://www.omg.org/gettingstarted/what_is_uml.htm
http://www.rational.com/uml/index.jsp
http://www.sparxsystems.com.au/UML_Tutorial.htm
http://www.togethersoft.com/services/practical_guides/umlonlinecourse/index.html
http://www.vico.org
http://www25.brinkster.com/educarodo/articulos/articulo0031.asp
http://www-gris.det.uvigo.es/~avilas/UML/node49.html
y otros mas...
para mayor informacin escribe a unlar@yahoo.com.ar