¿Qué quieres aprender?

Programación Orientada a Objetos

Programación Orientada a Objetos

Mundifor Centros de Formación

Curso online


235
IVA exento

Este curso aporta los conocimientos necesarios para conocer los principios del paradigma de la programación orientada a objetos y los modelos de programación web y bases de datos

¿Quieres hablar con un asesor sobre este curso?

Requisitos

Sin requisitos de acceso

Temario completo de este curso

UF 1. PRINCIPIOS DE LA PROGRAMACIÓN ORIENTADA A OBJETOSTema 1. Introducción al Paradigma Orientado a Objetos
  1. Ciclo de desarrollo del software bajo el paradigma de orientación a objetos: Análisis, diseño y programación orientada a objetos.
  2. Análisis del proceso de construcción de software: Modularidad.
  3. Distinción del concepto de módulo en el paradigma orientado a objetos.
  4. Identificación de objetos como abstracciones de las entidades del mundo real que se quiere modelar.
    1. Descripción de objetos: Conjunto de datos que definen un objeto y conjunto comportamientos que pueden solicitarse a los objetos.
    2. Identificación del comportamiento de un objeto: Concepto de mensaje.
Tema 2. Clases y Objetos
  1. Distinguir el concepto de clase y sus atributos, métodos y mecanismo de encapsulación:
    1. Relación entre interfaz y clase.
    2. Distinción de los tipos de datos y clases.
  2. Análisis de los objetos: Estado, comportamiento e identidad:
    1. Análisis de mensajes.
    2. Tipos de métodos y su clasificación: Métodos de acceso, de selección o consulta, de construcción, de destrucción.
  3. Uso de objetos como instancias de clase. Instancia actual (this, self, current).
  4. Identificación del concepto de programa en el paradigma orientado a objetos. POO = Objetos + Mensajes.
Tema 3. Generalización/Especialización: Herencia
  1. Descripción del concepto de herencia: Simple y múltiple:
    1. Relación de herencia: Características.
    2. Reglas y características que definen una relación de herencia: Regla «Es-un».
    3. Transmisión de atributos y métodos.
    4. Regla de especialización de la superclase en la subclase.
    5. Acceso a los atributos de una clase y acoplamiento entre las clases.
    6. Utilización de objetos this (current, self u otros) y super.
    7. Leyes de Demeter.
  2. Distinción de la herencia múltiple:
    1. Problemas: Conflictos de nombres, herencia repetida.
    2. Soluciones.
  3. Creación de objetos en la herencia.
  4. Clasificación jerárquica de las clases:
    1. Clase raíz.
    2. Clases abstractas.
    3. Métodos virtuales.
    4. Redefinición de métodos.
Tema 4. Relaciones entre Clases
  1. Distinción entre Agregación/Composición.
  2. Distinción entre Generalización / Especialización.
  3. Identificación de asociaciones.
Tema 5. Análisis del Poliformismo
  1. Concepto.
  2. Tipos:
    1. Polimorfismo en tiempo de compilación (sobrecarga).
    2. Polimorfismo en tiempo de ejecución (ligadura dinámica).
    3. Objetos polimórficos.
    4. Comprobación estática y dinámica de tipos.
Tema 6. Técnicas de Programación Estructurada
  1. Identificación de elementos básicos: constantes, variables, operadores y expresiones.
  2. Análisis de estructuras de control: Secuencial, condicional y de repetición.
  3. Distinción entre funciones y procedimientos:
    1. Interfaz.
    2. Paso de parámetros: Por valor y por referencia.
    3. Parámetros actuales y formales.
    4. Funciones: valor de retorno.
    5. Procedimientos.
    6. Ámbito de las variables.
    7. Almacenamiento de las variables.
  4. Demostración de llamadas a funciones y procedimientos.
  5. Empleo de llamadas a funciones y procedimientos incluidos en las clases:
    1. Llamadas calificadas y no calificadas (instancia actual).
    2. Paso de parámetros.
    3. Los atributos de la clase.
Tema 7. Estructura de la Información
  1. Enumeración de datos simples: Numéricos (enteros y reales), lógicos, carácter, cadena de caracteres, puntero o referencia a memoria.
  2. Datos estructurados: Arrays:
    1. Listas enlazadas, pilas y colas.
    2. Estructuras.
    3. Ficheros.
    4. Otras estructuras complejas: Tablas hash e Introducción a los árboles y grafos.
  3. Mecanismos de gestión de memoria:
    1. Uso de la gestión automática de memoria.
    2. Construcción y destrucción de objetos.
    3. Objetos inalcanzables.
    4. Recolección de «basura».
    5. Métodos constructores y destructores.
Tema 8. Lenguajes de Programación Orientados a Objetos
  1. Análisis del lenguaje de programación orientado a objetos y paradigma orientado a objetos:
    1. Lenguajes de programación orientados a objetos.
    2. Lenguajes de programación basados en objetos.
    3. Lenguajes de programación que utilizan objetos.
  2. Comparación entre los lenguajes de programación orientados a objetos más habituales. Características esenciales.
  3. Librerías de clases:
    1. Definición de su estructura.
    2. Creación y utilización.
Tema 9. Implementación del Paradigma Utilizando un Lenguaje de Programación Orientado a Objetos
  1. Elección del lenguaje.
  2. Enumeración de los tipos de aplicaciones.
  3. Herramientas de desarrollo.
  4. Tipos de datos y elementos básicos característicos del lenguaje. Instrucciones.
  5. Estudio y utilización de las clases básicas incluidas en la librería de clases.
  6. Definición de clases:
    1. Construcción de métodos. Sobrecarga.
    2. Construcción de atributos.
    3. Construcción de la interfaz de la clase.
    4. Construcción de clases incluyendo relaciones de Agregación /Composición y Asociación.
    5. Construcción de clases con herencia.
    6. Construcción de clases con herencia múltiple.
    7. Definición de clases abstractas.
    8. Construcción de clases con herencia incluyendo polimorfismo.
    9. Empleo de excepciones.
  7. Gestión de eventos:
    1. Eventos, fuentes y auditores de eventos.
    2. Tipos de eventos. Mecanismos de gestión de eventos.
    3. Librerías de clases asociadas.
  8. Empleo de hilos:
    1. Fundamentos.
    2. Creación.
    3. Prioridad.
    4. Comunicación.
    5. Sincronización.
    6. Estados.
    7. Creación y ejecución de hilos en el lenguaje.
    8. Librerías de clases asociadas.
    9. Programación multihilo.
  9. Definición y análisis de programación en red:
    1. Aplicaciones cliente servidor.
    2. Sockets.
  10. Acceso a bases de datos desde las aplicaciones. Librerías de clases asociadas.
UF 2. MODELO DE PROGRAMACIÓN WEB Y BASES DE DATOSTema 1. Introducción al Desarrollo de Aplicaciones en el Modelo de Programación Web
  1. Análisis de la arquitectura web: Cliente ligero, servidor web, servidor de aplicaciones, servidor de datos.
  2. Enumeración de protocolos y tecnologías habituales.
  3. Análisis de los modelos de programación estándares de facto.
  4. Uso de componentes orientados a objeto como base en el desarrollo de aplicaciones en el modelo de programación web.
Tema 2. Arquitectura Multicapa (N-TIER).
  1. Análisis de la arquitectura multicapa.
  2. Distinción y estudio del modelo de tres capas en web: presentación, aplicación y datos.
  3. Diseño de arquitecturas de aplicación basadas en el modelo multicapa.
  4. Análisis del concepto de lógica de negocio y significado de la capa lógica.
Tema 3. La Capa de Presentación
  1. Descripción de la capa de presentación: El lenguaje de hipertexto.
  2. Descripción de la capa de presentación avanzada: Lenguajes de scripting y lenguaje de hipertexto dinámico.
  3. Análisis de lenguajes orientados a la preparación de la capa de presentación y a la ejecución de solicitudes desde clientes ligeros web. (JSP, Servlets, ASP, PHP).
Tema 4. Diseño de Base de Datos Relacionales
  1. Definición de bases de datos relacionales.
  2. Diseño de bases de datos en varios niveles.
  3. Análisis de los distintos tipos de relaciones y su implementación en base de datos.
  4. Descripción del lenguaje de acceso a base de datos.
  5. Descripción de correlaciones entre el modelo relacional y modelo orientado a objetos.
  6. Nociones sobre el almacenamiento de objetos en las bases de datos relacionales.
Tema 5. Acceso a Base de Datos Relacionales: Capa de Acceso a Datos
  1. Análisis del API de acceso a la base de datos.
  2. Nivel controlador.
  3. Interfaz de acceso a la base de datos (driver).
  4. Análisis del nivel aplicación.
  5. Establecimiento de la conexión con una base de datos.
  6. Operar sobre la base de datos. Sentencias del lenguaje de acceso a base de datos. Objetos que permiten ejecutar una consulta. Objetos que permiten manipular el resultado de una consulta.
  7. Integración de los tipos de datos propios del lenguaje de acceso a base de datos en el lenguaje de programación de la aplicación.
  8. Procedimientos almacenados.
  9. Transacciones distribuidas.
Tema 6. Lenguajes de Definición de Datos
  1. Conceptos básicos, nociones y estándares.
  2. Lenguaje de definición de datos (DDL SQL) y aplicación en SGBD actuales.
  3. Discriminación de los elementos existentes en el estándar SQL-92 de otros elementos existentes en bases de datos comerciales.
  4. Sentencias de creación: CREATE:
    1. Bases de datos.
    2. Tablas.
    3. Vistas.
    4. Disparadores o Triggers.
    5. Procedimientos.
  5. Sentencias de modificación: ALTER:
    1. Bases de datos.
    2. Tablas.
    3. Vistas.
    4. Disparadores o Triggers.
    5. Procedimientos.
  6. Sentencias de borrado: DROP, TRUNCATE:
    1. Bases de datos.
    2. Tablas.
    3. Vistas.
    4. Disparadores o Triggers.
    5. Procedimientos.
Tema 7. Manipulación de los Datos
  1. Lenguaje de manipulación de datos (DML SQL).
  2. Consultas de datos: SELECT.
  3. Inserción de datos: INSERT.
  4. Modificación de datos: UPDATE.
  5. Eliminación de datos: DELETE.
  6. Agregación de conjuntos de datos para consulta: JOIN, UNION.
  7. Subconsultas.
Ver más