Programación Orientada a Objetos I
Antes de intentar aprender algo ten presente… lo complejo, alguna vez… fue simple, entiende lo simple.
El problema está en la técnica, no en la herramienta
Si no eres nuevo en esto de programar, pero aún no entiendes la orientación a objetos… deshazte de vicios y empieza nuevamente!
Listo?
Que es la orientación a objetos?
La orientación a objetos es un paradigma de programación
Típico! Si bien esta definición es correcta, el problema está, en que tanto lo comprendemos…
una forma de ver las cosas, o bien … A título personal… La orientación a objetos es “simplemente” una forma de ver las cosas, o bien …
…es una forma de entender un problema identificando las entidades principales que se encuentran en el..
La programación orientada a objetos (POO) es por tanto una forma de desarrollar un sistema, pensando en las entidades principales del problema que dicho sistema pretende resolver…
PINCIPIOS EN QUE SE APOYA LA TECNOLOGÍA O.O. Objeto como instancia de una Clase Métodos Mensajes
Artefacto más importante en el AOO Explica los conceptos más significativos en un dominio del problema. Previo a esto es fundamental establecer y perfeccionar el glosario del dominio En un modelo conceptual se ofrece una representación de cosas del mundo real, no de componentes de software.
Un modelo conceptual muestra: • Los conceptos. • Las asociaciones entre conceptos. • Los atributos de los conceptos. Un concepto se considera a partir de su: Símbolo * Definición * Extensión. Una distinción fundamental entre el AOO y el AE es la división por conceptos y no por funciones
la herramienta El lenguaje de programación es para resolver el problema El propósito de la POO no tiene que ver con el lenguaje de programación
conceptos relevantes presentes en el problema El propósito de la programación orientada a objetos consiste en… proporcionar una solución informática identificando los conceptos relevantes presentes en el problema
Identificar los conceptos relevantes o las entidades involucradas en un problema significa… reconocer las características de estos y las acciones que realizan o bien que producen algún efecto sobre ellos
Con respecto a los lenguajes de programación podemos decir que… cada uno usa la herramienta en que más hábil se considere, el problema finalmente no cambia
una u otra herramienta de trabajo De acuerdo a la situación con una u otra herramienta se nos hace más o menos difícil … y de acuerdo al escenario se debe elegir una u otra herramienta de trabajo
Veamos algunos conceptos clave… Qué es un Objeto?
Un Objeto es… Cualquier Cosa
En serio! Cualquier Cosa
Cualquier Cosa …de la que puedas emitir un concepto…
Es decir… Cualquier Cosa, todo es un objeto
…el mundo está lleno de objetos reales, los cuales se pueden representar como tales en una solución computarizada.
Veamos… Este es un objeto …es un automóvil de plástico, rojo con 4 llantas y 2 puertas
emitimos un concepto preconcebido Si realizáramos el proceso mental lentamente, nos daríamos cuenta de que al ver el objeto emitimos un concepto preconcebido es decir automóvil
En la imagen cada uno de los elementos que vemos es considerado un objeto Sin embargo de todos ellos podemos emitir un concepto conocido y para ello usamos la palabra globo
agrupación de objetos A ese concepto conocido que representa una …lo llamamos Clase
Una clase es como un molde de galletas… … este determina la forma y características que la galleta (el objeto) va a tener, sin ser el objeto real
El molde (la clase) no determina por ejemplo, que sabor tiene cada una de las galletas… …tampoco por cuanta cantidad de ingredientes estará compuesta.
La clase es una… …los objetos son todos los que podamos crear mentalmente a partir de dicha clase o concepto
La clase … … Describe un conjunto de objetos del Contexto del Problema, que tienen las mismas características y el mismo comportamiento
Hagamos un ejercicio, el típico… …el concepto que elegiremos es la clase persona
Este grupo de personas tiene un conjunto de características y comportamientos en común Nombre Edad Color de Piel Profesión Estado Civil Comportamientos Hablar Caminar Mirar Nacer Morir
Un objeto de la clase persona sería Características Nombre: Sandra Edad: 22 Color de Piel: Morena Profesión: Deportista Estado Civil: Soltera Comportamientos Hablar Caminar Mirar Nacer Morir
Otro objeto de la clase persona sería Características Nombre: Carlos Edad: 28 Color de Piel: Blanco Profesión: Abogado Estado Civil: Casado Comportamientos Hablar Caminar Mirar Nacer Morir
características (atributos o propiedades) Ya vamos entendiendo… Una clase esta compuesta por características (atributos o propiedades) y por comportamientos (acciones o métodos)
Las características y comportamientos de una clase son determinadas por el contexto del problema o escenario Esto en programación quiere decir, que dentro de un sistema, solo implementamos los atributos y métodos relacionados con el ámbito del problema que estamos solucionando.
Veamos algunos conceptos adicionales… A los valores que tienen los atributos de un objeto se les conoce como el estado del objeto, y a los atributos y métodos que ofrece se les conoce como la interfaz al código usado para construir las clases se le conoce como la implementación de la clase. Interfaz 1. f. Inform. Conexión física y funcional entre dos aparatos o sistemas independientes.
Los objetos se comunican con otros a través de mensajes Un mensaje es una comunicación dirigida a un objeto, que le ordena que ejecute uno de sus métodos con ciertos parámetros asociados al evento que lo generó. Wikipedia
Agregación/Composición Los objetos tienen diferentes tipos de relaciones Asociación Agregación/Composición
Ahora veamos conceptos avanzados
… la modularidad y la reusabilidad Los principios que dirigen la orientación a objetos son… … la modularidad y la reusabilidad Qué son?
En términos simples la modularidad significa trabajar por partes…
Y la reusabilidad significa No se invente la rueda! Lo que ya esta hecho es para usarse y algunas de las cosas que no están hechas, deben construirse pensando en que alguien necesitará usarlo alguna vez
… que tan claros los tenemos?…. Con respecto a la comunicación tenemos más principios alta cohesión y el bajo acoplamiento … que tan claros los tenemos?….
… el criterio de relación debe ser de negocio o técnico y no subjetivo Cuando decimos que un componente tiene una alta cohesión hablamos de que todos los elementos dentro de el están estrechamente relacionados … el criterio de relación debe ser de negocio o técnico y no subjetivo
Cuando decimos que un componente tiene una bajo acoplamiento hablamos del nivel de independencia que tiene un componente con respecto a otros
Características de la Orientación a Objetos
Abstracción Quitar propiedades y acciones de un objeto para dejar solo las necesarias Proceso mental que tiene dos aspectos complementarios El aspecto de destacar los detalles relevantes del objeto de estudio El aspecto de ignorar los detalles irrelevantes del objeto.
Encapsulamiento no puede ser manipulado directamente desde el exterior y su representación concreta es invisible.
Poseer todas las características de la clase de la que proviene Herencia Poseer todas las características de la clase de la que proviene La herencia permite modelar relaciones del tipo ...es es un… y clasificaciones
Polimorfismo Es la posibilidad de definir de forma distinta un método, dependiendo del objeto cada clase sabe como realizar tal operación
Beneficios de la tecnología de objetos 1. Permite desarrollar software en mucho menos tiempo y con menos coste. 2. Se consigue aumentar la calidad de los sistemas. 3. El software orientado a objetos es más fácil de modificar y mantener. 4. La tecnología de objetos facilita la adaptación al entorno y el cambio. 5. Fomenta una metodología basada en componentes 6. Utiliza en el análisis y diseño
Resumen Todo es un objeto Los objetos realizan operaciones (computan) solicitando servicios entre ellos a través del paso de mensajes Todo objeto es una instancia de una clase. Una clase agrupa objetos similares. En la clase se describe el comportamiento de los objetos. Las clases están organizadas en una jerarquía con una única raíz, llamada la jerarquía de herencia.
El secreto: un cambio de visión La POO no es, como muchos afirman, un paradigma distinto del de la programación procedural. Ambas son dos técnicas distintas para abordar la programación imperativa El secreto fundamental consiste en dejar de ver a un programa como un conjunto de acciones y funciones que modifican parámetros, para verlo como un conjunto de objetos con comportamiento, y a estos como estructuras que contienen acciones y funciones
Recomendaciones finales La POO representa un gran avance en la programación, tal como lo fue la programación estructurada en la década de los ‘70. Entre sus ventajas más importante se encuentran un notable aumento de la productividad del programador y de la robustez de los programas
La Programación orientación a objetos es… … una serie de normas, de realizar las cosas de manera que otras personas puedan utilizarlas y adelantar su trabajo, de manera que consigamos que el código se pueda reutilizar
IDEA BÁSICA DETRÁS DE LA PROGRAMACIÓN ORIENTADA A OBJETOS Lenguajes imperativos: Son aquellos basados en sentencias, ya sean procedurales, orientados a objetos puros o mixtos. Entre ellos se cuentan Pascal, C, C++, Java, Fortran, Perl y Python. Lenguajes procedurales: Son lenguajes imperativos basados en procedimientos (o rutinas) y funciones. Entre ellos podemos nombrar a C, Fortran, Pascal (estándar) y Basic
Lenguajes orientados a objetos Son lenguajes imperativos basados en clases (algunos, llamados mixtos soportan también el modelo procedural). Entre los lenguajes orientados a objetos puros podemos nombrar a Smalltalk, Eiffel y Java. Entre los mixtos se encuentran C++ y Python.
Lenguajes Funcionales … Son aquellos basados en funciones matemáticas (y no en comandos o sentencias). Podemos nombrar aquí a ML, Haskell y Lisp.
program personas; type persona = record nombre: string; apellido: string; edad: integer end; procedure inicializar(n, a: string; e: integer; var p: persona); begin p.nombre := n; p.apellido := a; p.edad := e end;
function es_mayor(p: persona): boolean; begin return p function es_mayor(p: persona): boolean; begin return p.edad >= 18 end; function nombre_completo(p: persona): string; begin return p.nombre + " " + p.apellido; end; var p: persona;
begin inicializar("Juan", "Perez", 25, p); write(nombre_completo(p)); if (es_mayor(p)) then writeln (" es mayor de edad.") else writeln (" es menor de edad.") end
En los programas procedurales hacemos esto todo el tiempo: definimos estructuras y tipos de datos y luego creamos procedimientos y funciones que toman como parámetros variables de estos tipos y realizan distintas operaciones sobre ellos. Dicho de otra manera: podemos ver a los programas procedurales como un conjunto de procedimientos y funciones que manipulan estructuras de datos pasadas como parámetros
Una visión diferente program personas; type persona = record nombre: string; apellido: string; edad: integer; procedure inicializar(n, a: string; e: integer); begin nombre := n; apellido := a; edad := e end; function es_mayor: boolean; begin return edad >= 18 end;
function nombre_completo: string; begin return nombre + " " + apellido; end var p: persona; begin p.inicializar("Juan", "Perez", 25); write(p.nombre_completo); if (p.es_mayor) then writeln (" es mayor de edad.") else writeln (" es menor de edad.") end.
Una diferencia importante de notación a la hora de usar la estructura de datos definida, es que ya no utilizamos expresiones de la forma funcion(variable), sino que ahora escribimos variable.funcion. Una ventaja adicional es que la notación es más consistente. Al referirnos a p.nombre_completo no podemos saber (porque en realidad no interesa) si nombre_completo es un campo del registro o una función. Esto es realmente importante: en el caso del campo edad este podría ser reemplazado por una función que calcule la edad de la persona, añadiendo un campo que represente la fecha de nacimiento. De ocurrir esto, los programas que usen el tipo persona no requerirían mayores modificaciones, ya que podrían seguir haciendo referencia a p.edad. Esto facilita la independencia de la implementación y el encapsulamiento, uno de los conceptos claves de la POO.
AJUSTANDO NUESTRO VOCABULARIO A lo que antes llamábamos tipo, refiriéndonos a estructuras de datos, ahora lo llamamos clase, entendiendo como tal no sólo las estructuras, sino también el comportamiento asociado (las acciones y funciones asociadas directamente con la estructura de datos). A lo que antes llamábamos variable ahora lo llamamos objeto. Así como las variables son de determinado tipo, los objetos son de determinada clase.
Los procedimientos y funciones definidos dentro de una clase se llaman métodos, en tanto que los campos se denominan atributos. En nuestro ejemplo, podríamos decir que la clase persona tiene los atributos nombre, apellido y edad, y los métodos inicializar, nombre_completo y es_mayor.
Un concepto importante: la herencia En la POO existe la posibilidad de extender el comportamiento de una clase, añadiendo atributos y métodos. El mecanismo utilizado para tal fin se denomina herencia. Siguiendo con nuestro ejemplo, podríamos querer definir una clase empleado. Básicamente un empleado posee todas las características de una persona (tiene nombre y apellido, tiene sentido preguntarse si es mayor de edad, etc.). Sin embargo, un empleado tendrá otros atributos (por ejemplo, un salario, un cargo) y también otros métodos (liquidar_salario, etc.). Es por esto que bastará con definir a la clase empleado heredando de la clase persona (en POO se usa la expresión “un empleado es una persona“), y añadiendo el nuevo comportamiento (métodos y atributos).
ANEXO: Un ejemplo en PHP es un lenguaje con un sistema de tipos dinámico (una característica que lo hace muy simple y rápido para pequeños desarrollos, pero que se vuelve un arma de doble filo en programas complejos). <? function inicializar($nombre, $apellido, $edad) { $persona['nombre'] = $nombre; $persona['apellido'] = $apellido; $persona['edad'] = $edad; return $persona; } function nombre_completo($persona) { return $persona['nombre'] . ' ' .$persona['apellido']; } function es_mayor($persona) { return $persona['edad'] >= 18; } $p = inicializar('Juan', 'Perez', 25); echo nombre_completo($p); if (es_mayor($p)) { echo " es mayor de edad.\n"; } else { echo " es menor de edad.\n"; } ?>