Nombre: PROGRAMACIÓN PARA INGENIERÍA TELEMÁTICA
Código: 505103004
Carácter: Obligatoria
ECTS: 6
Unidad Temporal: Cuatrimestral
Despliegue Temporal: Curso 3º - Primer cuatrimestre
Menciones/Especialidades:
Lengua en la que se imparte: Castellano
Carácter: Presencial
Nombre y apellidos:
Nombre y apellidos:
Nombre y apellidos:
[CG3 ]. Conocimiento de materias básicas y tecnologías, que le capacite para el aprendizaje de nuevos métodos y tecnologías, así como que le dote de una gran versatilidad para adaptarse a nuevas situaciones.
[T1 ]. Capacidad de construir, explotar y gestionar las redes, servicios, procesos y aplicaciones de telecomunicaciones, entendidas éstas como sistemas de captación, transporte, representación, procesado, almacenamiento, gestión y presentación de información multimedia, desde el punto de vista de los servicios telemáticos
[T4 ]. Capacidad de describir, programar, validar y optimizar protocolos e interfaces de comunicación en los diferentes niveles de una arquitectura de redes
[T7 ]. Capacidad de programación de servicios y aplicaciones telemáticas, en red y distribuidas
[TR2 ]. Trabajar en equipo
[TR5 ]. Aplicar a la práctica los conocimientos adquiridos
Al finalizar el plan formativo, el estudiante debe ser capaz de:
Describir los elementos principales del modelo entidad-relación y del modelo relacional y relacionarlos entre sí. Describir los elementos principales del lenguaje SQL. Realizar consultas SQL, principalmente SELECT, de mediana complejidad.
Enumerar y describir los principios generales de la programación orientada a objetos.
Describir e identificar algunos patrones de diseño comúnmente usados en el diseño de aplicaciones interactivas y distribuidas (estrategia, observador, delegación, composición, modelo-vista-controlador, etc.).
Describir e identificar políticas de concurrencia comúnmente en el diseño de aplicaciones interactivas y distribuidas (ejecutivo cíclico, hilo por petición, pilas de hilos, etc.).
Diseñar, implementar y validar a partir de una especificación una aplicación interactiva con una interfaz gráfica de pequeña complejidad en la que (1) se creen tipos de datos (2) se utilice la relación de composición para crear objetos compuestos (3) se haga uso del polimorfismo y (4) se definan manejadores de eventos asociados a los elementos de la interfaz de usuario.
Diseñar, implementar y validar a partir de una especificación, una pequeña aplicación distribuida en la que (1) se utilicen diferentes políticas de concurrencia para aceptar y procesar las peticiones de servicio, (2) se utilicen comunicaciones asíncronas entre clientes y servidores, (3) se proporcionen mecanismos para añadir manejadores de servicios y (4) se acceda a bases de datos.
Aspectos avanzados de la programación orientada a objetos. Procesos e hilos. Comunicación entre procesos. Gestión de memoria. Acceso a bases de datos desde lenguajes de programación.
Unidad didáctica I. - Introducción a las bases de datos.
1.1.- Introducción a las BBDD.
1.2.- Modelos ER y relacional.
1.3.- Introducción al lenguaje SQL.
1.4.- Otros tipos de bases de datos.
1.4.- Acceso a BBDD desde aplicaciones Java.
Unidad didáctica II.- Aspectos avanzados de la programación orientada a objetos
2.1. Repaso de conceptos fundamentales de la POO. Tipos abstractos de datos, clases e interfaces, herencia y composición.
2.2. Excepciones y E/S en Java. Patrón decorador.
2.3. Interfaces Gráficas de usuario (I). Organización jerárquica. Patrones composite y estrategia.
2.4. Interfaces Gráficas de usuario (II).Programación conducida por eventos. Patrón observador. Patrón MVC.
2.5. Contenedores e iteradores. Programación genérica.
Unidad didáctica III.- Introducción a la programación concurrente y distribuida.
3.1. Programación concurrente. Procesos e hilos. Sincronización y comunicación. Eventos y concurrencia.
3.2. Políticas de concurrencia (I). Servidores iterativos y concurrentes.
3.3. Políticas de concurrencia (II). Pilas de hilos y objeto activo.
3.4. Librerías para programar concurrencia en Java.
Unidad didáctica I: Bases de Datos
Sesión 1: Instalación de gestor y cliente de BBDD. Sesión 2: Implementación de una BBDD a partir de un modelo E-R. Consultas SQL. Sesión 3: Consultas SQL. Conexión de la BBDD con un programa Java. Sesión 4: Evaluación del bloque I. Evaluación de la práctica y examen de la práctica.
Unidad didáctica II: Programación orientada a objetos
Sesión 5: Excepciones. E/S a ficheros y a BBDD. Sesiones 6, 7, 8: Aplicación interactiva con una interfaz gráfica de usuario y conexión a BBDD. Sesión 9: Evaluación del bloque II. Evaluación de la práctica y examen de la práctica
Unidad didáctica III: Programación concurrente y distribuida
Sesión 10: Programación concurrente. Hilos y exclusión mutua. Servidores iterativos y concurrentes. Sesiones 11, 12, 13: Servidor de acceso a BBDD con distintas políticas de concurrencia. Sesión 14: Evaluación del bloque III. Evaluación de la práctica y examen de la práctica.
La Universidad Politécnica de Cartagena considera como uno de sus principios básicos y objetivos fundamentales la promoción de la mejora continua de las condiciones de trabajo y estudio de toda la Comunidad Universitaria. Este compromiso con la prevención y las responsabilidades que se derivan atañe a todos los niveles que integran la Universidad: órganos de gobierno, equipo de dirección, personal docente e investigador, personal de administración y servicios y estudiantes. El Servicio de Prevención de Riesgos Laborales de la UPCT ha elaborado un "Manual de acogida al estudiante en materia de prevención de riesgos" que puedes encontrar en el Aula Virtual, y en el que encontraras instrucciones y recomendaciones acerca de cómo actuar de forma correcta, desde el punto de vista de la prevención (seguridad, ergonomía, etc.), cuando desarrolles cualquier tipo de actividad en la Universidad. También encontrarás recomendaciones sobre cómo proceder en caso de emergencia o que se produzca algún incidente. En especial, cuando realices prácticas docentes en laboratorios, talleres o trabajo de campo, debes seguir todas las instrucciones del profesorado, que es la persona responsable de tu seguridad y salud durante su realización. Consúltale todas las dudas que te surjan y no pongas en riesgo tu seguridad ni la de tus compañeros.
Block I. - Introduction to databases.
1.1 -. Introduction to Data Bases.
1.2 -. E-R and relational models.
1.3 -. Introduction to the SQL language.
1.4 -. Other types of data bases.
1.4 -. Access to DB from Java applications.
Block II -. Advanced aspects of object-oriented programming (OOP).
2.1. Review of OOP fundamental concepts. Abstract data types, classes and interfaces, inheritance and composition.
2.2. Exceptions and IO in Java. Decorator pattern.
2.3. Graphic User Interfaces (I). Hierarchical organization. Composite and strategy patterns..
2.4. Graphic User Interface (II). Event-driven programming. Observer pattern. MVC Pattern.
2.5. Containers and iterators. Generic programming.
Block III -. Introduction to concurrent and distributed programming.
3.1. Concurrent programming. Processes and threads. Synchronization and communication. Events and attendance.
3.2. Concurrency policies (I). Iterative and concurrent servers.
3.3. Concurrency Policies (II). Thread pools and active object.
3.4. Concurrency libraries for programming in Java
Cada unidad didáctica tiene una práctica entregable y un parcial.
(1) Los alumnos que no entreguen las prácticas o tengan en ellas una calificación inferior a 5.0 deberán realizar ejercicios adicionales en el examen final.
(2) Los alumnos con más de tres ausencias a prácticas también deberán realizar ejercicios adicionales en el examen final.
(3) La nota de la práctica evaluable sólo será tenida en cuenta si la nota del parcial correspondiente es superior a 5. Si la nota del parcial es menor que 5 al alumno se le aplicará la nota obtenida en
el parcial que pasará a tener el mismo peso que el conjunto entregable-parcial.
(4) Si la nota del examen final es superior a la media ponderada de las notas acumuladas (incluido el final), la nota final de la asignatura será la del examen final.
Aquellos alumnos repetidores que hubieran aprobado las prácticas en el itinerario en español y se matriculen en el itinerario en inglés deberán volver a realizar las prácticas para que se les
reconozca el itinerario en inglés.
Clase en aula convencional: teoría, problemas, casos prácticos, seminarios, etc
Clase expositiva de conceptos teórico - prácticos
Clase orientada a la resolución de problemas y caso de estudio
32
100
Clase en laboratorio: prácticas
Clase práctica en laboratorio
0
100
Clase en campo o aula abierta (visitas técnicas, conferencias, etc.). En general, actividades que requieren de unos recursos o de una planificación especiales
Clase práctica en laboratorio
0
100
Clase en aula de informática: prácticas
Prácticas en el aula de informática
24
100
Actividades de evaluación (sistema de evaluación continua)
Realización de pruebas de evaluación (tiempo de duración de los exámenes y otras pruebas de evaluación en el aula)
4
100
Actividades de evaluación (sistema de evaluación final)
Actividades de evaluación final
0
100
Tutorías
Tutorías grupales o individuales
0
50
Trabajo del estudiante: estudio o realización de trabajos individuales o en grupo
Preparación de trabajos y ejercicios (incluye tiempo para consulta bibliográfica y documentación)
Sistema de evaluación final: pruebas complementarias (integración de actividades realizadas durante el curso)
120
0
Exámenes escritos y/u orales (evaluación de contenidos teóricos, aplicados y/o prácticas de laboratorio)
Exámenes escritos y/u orales (evaluación de contenidos teóricos, aplicados y/o prácticas de laboratorio)
2 parciales: Parcial 1 40% (Orientación a Objetos), Parcial 2 (20%) Concurrencia + Bases datos
60 %
Tablas de observación para evaluar el desempeño de actividades (incluidas las prácticas de laboratorio) sobre las que no se requiera documentación escrita
Tablas de observación para evaluar el desempeño de actividades (incluidas las prácticas de laboratorio) sobre las que no se requiera documentación escrita
0 %
Entregables de ejercicios y/o prácticas
Entregables de ejercicios y/o prácticas de laboratorio y posterior entrevista personal
Dos entregables de 20% cada uno
40 %
Exámenes escritos y/u orales (evaluación de contenidos teóricos y/o aplicados de la asignatura)
Exámenes escritos y/u orales (evaluación de contenidos teóricos, aplicados y/o prácticas de laboratorio)
2 parciales: Parcial 1 40% (Orientación a Objetos), Parcial 2 (20%) Concurrencia + Bases datos
60 %
Exámenes escritos y/u orales (evaluación de prácticas de laboratorio)
Entrevista personal oral sobre los entregables de ejercicios prácticos.
0 %
Entregables de ejercicios y/o prácticas
Entregables de ejercicios y/o prácticas de laboratorio y posterior entrevista personal
Dos entregables de 20% cada uno
40 %
Clase de teoría
Resolución de problemas tipo y casos prácticos
Prácticas
Según el artículo 8.3 de la normativa de evaluación vigente, el alumno que se presente a una actividad del sistema de evaluación final habiendo superado las calificaciones mínimas de la actividad correspondiente del sistema de evaluación continua, no tiene que renunciar a la calificación obtenida en dicha actividad del sistema de evaluación continua en la convocatoria en que se presente a la misma.
Autor: Deitel, H.M.
Título: Java how to program
Editorial: Prentice Hall
Fecha Publicación: 2002
ISBN: 0130341517
Unidad Didáctica 1:
Matilde Celma, ¿Bases de datos relacionales¿, Pearson Education, 2006 (disponible en biblioteca).
- Capítulos 1, 2, 3 y 4. Se indicará a los alumnos las secciones que deben estudiarse.
- Apuntes de la asignatura disponibles en aula virtual.
Unidad Didáctica 2:
Java How To Program, 8ª edición (disponible en biblioteca).
- Capítulos 7 a 10 (orientación a objetos), 11 (excepciones), 17 (E/S), 14 (Guis, layouts y
eventos), 20 a 22 (programación genérica y estructuras de datos). Se indicará a los alumnos
las secciones que deben estudiarse.
- Apuntes de la asignatura disponibles en aula virtual.
Unidad Didáctica 3:
- Tutorial sobre programación concurrente de Oracle:
http://docs.oracle.com/javase/tutorial/essential/concurrency/index.html. Se indicará a los
alumnos las secciones que deben estudiarse.
Apuntes de la asignatura disponibles en aula virtual.