Trabajo de investigación
Si quieren informarse mas sobre la Programación Orientada a Objetos, visita mi blog aquí les dejo un link:
http://bloggerlisevelinvasquez.blogspot.pe/2017/04/programacion-orientada-objetos.html
POO: Introducción a los conceptos y características básicas de la Programación Orientada a Objetos
1.
2. DEFINICIÓN :
• POO u (OOP según sus siglas en inglés): es un
paradigma de programación que usa objetos y sus
interacciones para diseñar aplicaciones y programas de
computadora. Está basado en varias técnicas,
incluyendo herencia, modularidad, polimorfismo, y
encapsulamiento.
4. CLASE
• Una clase es una plantilla que define las variables y los
métodos que son comunes para todos los objetos de un
cierto tipo. Por lo tanto, para que pueda haber objetos,
antes debe haberse definido las clases a las que
pertenecerán dichos objetos.
5. PARTE PÚBLICA
• Describe a qué operaciones responden los objetos de una clase
(cómo se comportan los objetos). En esta parte de la clase se
declaran las cabeceras de los métodos de la clase que podrán ser
"invocados" por los objetos.
PARTE PRIVADA
• Describe los datos de la clase y cómo las operaciones manipulan
dichos datos. Esta parte de la clase es donde se oculta (encapsula)
la información de la clase.
6.
7. OBJETO
• Un objeto es un ejemplar concreto de una clase, como
por ejemplo el curso de metodología de la programación
es un curso concreto dentro de todos los tipos de
cursos que pueden existir. Un objeto pertenece a una
clase, por lo tanto dispondrá de los atributos (datos) y
operaciones (métodos) de la clase a la que pertenece.
8. • Tras ser instanciado, un objeto consta de los atributos de la
clase a la que pertenece, y puede recibir mensajes. Dicho
objeto determinará a qué método de su clase corresponde
dicho mensaje. Un objeto no podrá recibir mensajes
correspondientes a métodos de una clase a la que no
pertenezca. Por ejemplo:
10. La siguiente figura muestra las tres partes que componen un
mensaje:
1. El objeto al cual se manda el mensaje (TuBicicleta).
2. El método o función miembro que debe ejecutar (CambiarDeMarcha).
3. Los parámetros que necesita ese método (Marcha)
11. HERENCIA
• Consideraremos la herencia como la transmisión de los
métodos y atributos de una clase a otra. Gracias a la
herencia se pueden establecer jerarquías entre clases.
Establecer una jerarquía es un proceso subjetivo.
12.
13. MÉTODO
• Son las operaciones (acciones o funciones) que se
aplican sobre los objetos y que permiten crearlos,
cambiar su estado o consultar el valor de sus atributos.
• constituyen la secuencia de acciones que implementan
las operaciones sobre los objetos.
• puede producir un cambio en las propiedades del objeto.
14. • Para funciones se pueden usar cualquiera de estas dos
sintaxis:
<Modo de Acceso> Función <Nombre> [(Lista
Parámetros)]: <Descripción del Tipo de datos>
• Para acciones:
<Modo de Acceso> Acción <Nombre> [(Lista
Parámetros)] donde los parámetros son opcionales
15. ATRIBUTOS
• Características que aplican al objeto solo en el caso
en que él sea visible en pantalla por el usuario;
entonces sus atributos son el aspecto que refleja,
tanto en color, tamaño, posición, si está o no
habilitado.
16. PROPIEDAD O ATRIBUTO
• Contenedor de un tipo de datos asociados a un objeto
(o a una clase de objetos), que hace los datos visibles
desde fuera del objeto y esto se define como sus
características predeterminadas, y cuyo valor puede
ser alterado por la ejecución de algún método.
17. EVENTOS
• Son aquellas acciones mediante las cuales el objeto
reconoce que se está interactuando con él. De esta forma el
objeto se activa y responde al evento según lo programado
en su código.
• Es un suceso en el sistema (tal como una interacción del
usuario con la máquina, o un mensaje enviado por un
objeto). El sistema maneja el evento enviando el mensaje
adecuado al objeto pertinente. También se puede definir
como evento la reacción que puede desencadenar un objeto;
es decir, la acción que genera.
18. INSTANCIA
• Se llama instancia a todo objeto que derive de algún
otro. De esta forma, todos los objetos son instancias
de algún otro, menos la clase Object que es la madre
de todas.
19. ESTADO INTERNO
• Es una variable que se declara privada, que puede ser
únicamente accedida y alterada por un método del
objeto, y que se utiliza para indicar distintas
situaciones posibles para el objeto (o clase de
objetos). No es visible al programador que maneja una
instancia de la clase.
20. SOBRECARGA
• La sobrecarga consiste en poder crear un mismo
método tantas veces como se quiera, pero han de
tener diferentes "lista de argumentos”.
21. podemos crear un método:
public void unMetodo(){
//código
}
Y lo podemos sobrecargar de la
siguiente manera:
public void unMetodo(int x){
//código
}
22. Como veis, el método es el mismo, se llaman igual, pero
tienen diferente lista de argumentos. Estas distintas
versiones pueden estar en una misma clase o repartidos
entre esta y su "superclase".
23. UN MÉTODO SOBRECARGADO PUEDE TENER:
• Diferente tipo de retorno.
• Diferentes modificadores de acceso.
• Lanzar diferentes excepciones.
24. CLASES ABSTRACTAS
• Las clases abstractas, las cuales declaran con la palabra clave
abstract, no se pueden crear instancias. Sólo puede ser
utilizado como un super-clase para otras clases que amplían la
clase abstracta.
26. LA ABSTRACCIÓN
• Por un lado nos permite referirnos a objetos para representar
la realidad, describiendo el problema en términos del
problema en lugar de en términos de la solución.
• La clave de la programación orientada a objetos está en
abstraer los métodos y los datos comunes a un conjunto de
objetos y agruparlos en una clase.
• Gracias a este nivel de abstracción, añadir o eliminar un
objeto nuevo supondrá muy poco esfuerzo.
27. ENCAPSULAMIENTO
• Se refiere a la capacidad de agrupar y condensar en un
entorno con límites bien-definidos distintos elementos.
Cuando hablamos de encapsulación en general siempre
nos referiremos a encapsulación abstracta. De manera
informal, primero generalizamos (la abstracción) y luego
decimos: la generalización está bien, pero dentro de un
cierto orden: hay que poner límites (la encapsulación), y
dentro de esos límites vamos a meter todo lo
relacionado con lo abstraído: no sólo datos, sino
también métodos, comportamientos, etc.
28. POLIMORFISMO
• Esta característica permite definir distintos
comportamientos para un método dependiendo de la clase
sobre la que se realice la implementación. En todo
momento tenemos un único medio de acceso, sin embargo
se podrá acceder a métodos distintos.
• El polimorfismo se puede establecer mediante la
sobrecarga de identificadores y operadores, la ligadura
dinámica y las funciones virtuales. El término sobrecarga
se refiere al uso del mismo identificador u operador en
distintos contextos y con distintos significados.
29. MODULARIDAD
• Es la propiedad que permite subdividir una aplicación en
partes más pequeñas (llamadas módulos), cada una de
las cuales debe ser tan independiente como sea posible
de la aplicación en sí y de las restantes partes. Estos
módulos se pueden compilar por separado, pero tienen
conexiones con otros módulos. Al igual que la
encapsulación, los lenguajes soportan la modularidad
de diversas formas.
30. PRINCIPIO DE OCULTACIÓN
• Cada objeto está aislado del exterior, es un módulo
natural, y cada tipo de objeto expone una "interfaz" a
otros objetos que especifican cómo pueden interactuar
con los objetos de la clase. El aislamiento protege a
las propiedades de un objeto contra su modificación
por quien no tenga derecho a acceder a ellas;
solamente los propios métodos internos del objeto
pueden acceder a su estado.
31. COHESIÓN
• Cohesión es “Es la medida de cuanto una entidad
(componente o clase) se encuentra especializada
en propósito único dentro de un sistema”.
32. INTERFACES
• Una interface se compone de “Un conjunto de
operaciones que caracterizan el comportamiento de
un elemento”. Todos los métodos definidos en una
interface son public abstract. En resumen, la interface
separa la aplicación y define la estructura, y este
concepto es muy útil en los casos donde se necesita la
aplicación para ser intercambiables.
33. ACOPLAMIENTO
• Mide el grado de relacionamiento de un módulo con los
demás. A menor acoplamiento, mejor: el módulo en
cuestión será más sencillo de diseñar, programar, probar y
mantener. En el diseño estructurado, se logra bajo
acoplamiento reduciendo las interacciones entre
procedimientos y funciones, reduciendo la cantidad y
complejidad de los parámetros y disminuyendo al mínimo
los parámetros por referencia y los efectos colaterales.
34. ASOCIACIÓN
• Es una relación entre dos clases. Permite que una instancia de
objeto de causar otro para llevar a cabo una acción en su
nombre. Asociación es el término más general que define la
relación entre dos clases, donde como la agregación y la
composición son relativamente especial.
Ejemplo: En este caso podemos decir que existe una asociación
entre StudentRegistrar y RecordManager o existe una relación
direccional de StudentRegistrar a RecordManager o
StudentRegistrar utilizar una RecordManager. Puesto que se
especifica explícitamente una dirección, en este caso, la clase del
controlador es la StudentRegistrar.
36. • Los objetos son el elemento central de la programación
en Visual Basic. Los formularios y controles son objetos.
Las bases de datos son objetos. Si ha usado Visual
Basic durante algún tiempo, o si ha trabajado con los
ejemplos de la documentación, ya han programado con
objetos, pero hay mucho más en lo que se refiere a
objetos de lo que ha visto hasta aquí.
• En los siguientes temas, verá lo fácil que resulta crear
objetos propios a partir de las clases que defina, así
como utilizar objetos para simplificar la creación de
código y aumentar su reutilización.
37. INTRODUCCIÓNA LOS OBJETOSEN
VISUALBASIC
• Un objeto es una estructura
que contiene la información y
los métodos que manipulan
los datos. Casi todas las
tareas realizadas en Visual
Basic están asociadas con
objetos. Si no tiene
experiencia en programación
orientada a objetos, los
siguientes términos y
conceptos le ayudarán a
comenzar.
CLASESY OBJETOS
En general, una clase es una
representación abstracta de
algo, mientras que un objeto es
un ejemplo utilizable de lo que
representa la clase. La única
excepción a esta regla la
constituyen los miembros de
clases compartidas, que
pueden utilizarse en instancias
de una clase y en variables de
objeto declaradas como tipo de
la clase.
38. CAMPOS, PROPIEDADES, MÉTODOS Y EVENTOS
• Los campos y propiedades representan información que contiene un objeto. Los
campos se parecen a las variables ya que se pueden leer y establecer
directamente. Por ejemplo, si tiene un objeto denominado "Car", podría
almacenar su color en un campo denominado "Color".
• Las propiedades se recuperan y establecen como los campos, pero se
implementan mediante los procedimientos propiedad Get y Set, que
proporcionan más control sobre la forma en que los valores se establecen o se
devuelven. El nivel de direccionamiento indirecto entre el valor que se va a
almacenar y los procedimientos que lo usan ayuda a aislar los datos y permite
validar valores antes de asignarlos o recuperarlos.
• Los métodos representan acciones que un objeto puede realizar.
39. ENCAPSULACIÓN, HERENCIAY POLIMORFISMO
• La encapsulación significa que un grupo de propiedades, métodos y
otros miembros relacionados se tratan como si de una sola unidad u
objeto se tratase. Los objetos pueden controlar cómo se cambian
propiedades o se ejecutan métodos.
• Herencia describe la posibilidad de crear nuevas clases basadas en
una clase existente. La nueva clase hereda todas las propiedades,
métodos y eventos de la clase base, y puede personalizarse con
propiedades y métodos adicionales.
• Polimorfismo significa que puede tener múltiples clases que se pueden
utilizar de forma intercambiable, si bien cada clase implementa las
mismas propiedades o los mismos métodos de maneras diferentes.
40. SOBRECARGA, REEMPLAZOY SOMBREADO
• Los miembros sobrecargados se utilizan para proporcionar diferentes
versiones de una propiedad o método que tienen el mismo nombre, pero
que aceptan un número diferente de parámetros, o parámetros con
diferentes tipos de datos.
• Las propiedades y métodos reemplazados se utilizan para reemplazar una
propiedad o métodos heredados que no son apropiados en una clase
derivada.
• Los miembros sombreados se utilizan para reemplazar localmente un
miembro que tiene un ámbito más amplio. Cualquier tipo puede sombrear
cualquier otro tipo.