Download Introducción a los lenguajes de programación
Document related concepts
Transcript
Introducción a los lenguajes de programación Informática aplicada al medio ambiente curso 2010/2011 Lenguajes de programación y traductores Niveles de abstracción en lenguajes de programación: bajo-alto nivel. Traductores: compilador e intérprete. Proceso de compilación: errores. Clasificación de los lenguajes. Informática aplicada al Medio Ambiente 2 Máquina de turing Modelo formal de un computador (Alan Turing 1936) Elementos: Cinta infinita dividida en celdas con valores Autómata Estado y Valor cinta → Nuevo estado, nuevo valor y avance (izquierda o derecha) Describe cualquier algoritmo (universal) Ejemplo: http://ironphoenix.org/tril/tm/ Informática aplicada al Medio Ambiente 3 Niveles de lenguajes: bajo nivel Código máquina Único lenguaje que entiende el ordenador. Difícil de entender para los humanos. Permite aprovechar al máximo los recursos. Instrucciones codificadas en binario. Particular de cada procesador. Informática aplicada al Medio Ambiente 4 Niveles de lenguajes: bajo nivel Ensamblador: Representación mnemotécnica del código máquina: Particular de cada procesador. Cada instrucción en ensamblador equivale a una instrucción en lenguaje máquina. Símbolos para representar las instrucciones y para las direcciones de memoria. Se requiere un programa traductor. (llamado también ensamblador) Informática aplicada al Medio Ambiente 5 Ejemplo de código ... subl $8, %esp andl $-16, %esp subl $28, %esp pushl $.LC0 call printf addl $12, %esp leal -4(%ebp), %ecx pushl %ecx leal -8(%ebp), %edx pushl %edx pushl $.LC1 Informática aplicada al Medio Ambiente ... 6 Niveles de lenguajes: alto nivel Independientes de la estructura concreta del ordenador. Se aproxima más al lenguaje natural. Utiliza variables y estructuras de datos para representar la información. Utiliza estructuras de control: condicionales y bucles. Se han de traducir a lenguaje máquina. Una instrucción del LA se traduce a varias instrucciones en lenguaje máquina (LB). Informática aplicada al Medio Ambiente 7 Ejemplos de código ADA with Ada.Text_IO; C++ #include <iostream> using namespace std; procedure Hola_Mundo is begin Ada.Text_IO.Put("¡Hola, mundo!"); end Hola_Mundo; int main() { cout << "¡Hola, mundo!" << endl; } Informática aplicada al Medio Ambiente 8 Ejemplos de código MATLAB function ejemplo1() % Funcion para sumar dos números % x = input('Introduzca el valor de x e y: ') y = input('') z=x+y disp(['El resultado de hacer x+y es: ' int2str(z)]) Informática aplicada al Medio Ambiente 9 Programas traductores Pasan del lenguaje de alto nivel al código máquina correspondiente. Pueden ser: Compiladores Interpretes Informática aplicada al Medio Ambiente 10 Compiladores Traducen completamente un programa fuente, generando el programa objeto equivalente en lenguaje máquina. El programa objeto se guarda en un fichero y se puede ejecutar sin necesidad del compilador. Ejemplos de lenguajes compilados: C, C++, Pascal, Fortran… Informática aplicada al Medio Ambiente 11 Intérpretes Traduce y ejecuta instrucción a instrucción en el interprete. No se guarda ningún fichero de programa objeto: Menos eficiente: más lento. Más interactivo. Ejemplo de lenguajes interpretados: Java (no del todo), Javascript, Matlab, Basic, PHP… Informática aplicada al Medio Ambiente 12 Interpretación/compilación y ejecución Interpretado Análisis: Compilado Léxico Sintáctico Semántico Análisis: Generación de código Ejecución de código Ejecución: Es necesario tener los fuentes y los datos. Léxico Sintáctico Semántico Generación y optimizacón de código Ejecución de código Ejecución: Solo es necesario tener el ejecutable y los datos Informática aplicada al Medio Ambiente 13 Tipos de errores de compilación Léxicos: palabras no reconocidas Sintácticos: construcciones incorrectas. whyle (x>0) if (a>b>c) Semánticos: construcciones correctas, pero sin sentido. int x; ... x[3] = 5; Informática aplicada al Medio Ambiente 14 Errores no detectados por el compilador Lógicos: algoritmo incorrecto. Ej. Intercambiar a y b : /*MAL*/ temp = a; b = a; b = temp; /*OK*/ temp = a; a = b; b = temp; De ejecución: relacionados con situaciones de la ejecución del programa: División por 0 Raíz cuadrada de un número negativo Acceder a un elemento inexistente de un vector ... Informática aplicada al Medio Ambiente 15 Lenguajes de alto nivel según el ámbito de su aplicación: Científicos: Fortran, Matlab, Mathematica. De gestión: COBOL, SQL. De uso docente: Logo, Pascal. De inteligencia artificial: LISP, PROLOG. De propósito general: Java, C / C++… Informática aplicada al Medio Ambiente 16 Primeros programas Charles Babagge → Máquina analítica (siglo XIX) Ada Lovedby se considera la primera programadora de la historia Se empleaban tarjetas perforadas ADA es un lenguaje moderno, departamento de defensa EE.UU Informática aplicada al Medio Ambiente 17 Breve Historia Lenguajes Programación 1943-46: Sistema de codificación del ENIAC 1954 Definición del Primer Lenguaje de Alto Nivel: FORTRAN 1957 Primera implementación de FORTRAN. Desarrollado por IBM Informática aplicada al Medio Ambiente 18 Breve Historia Lenguajes Programación Años 60 Desarrollo de la programación estructurada: Se populariza en los años 70 A partir de las ideal del lenguaje ALGOL Programas son construidos con tres estructuras de control de bajo nivel: Bloque o sucesión de instrucciones Ejecución condicional: if- then – else Bucles de instrucciones de ejecución repetitiva condicional: while, for Informática aplicada al Medio Ambiente 19 Breve Historia Lenguajes Programación Incorporan la programación estructura en los lenguajes no estructurados: FORTRAN 77, COBOL, BASIC. Aparecen nuevos lenguajes: PASCAL, MODULA y C. Informática aplicada al Medio Ambiente 20 C Autores: Kernighan & Ritchie (1972) Lenguaje de alto nivel estructurado: Con funciones Objetivo inicial: Utilización para la programación de sistemas operativos.. Windows, Unix. Se buscó deliberadamente una proximidad con lenguajes de nivel más bajo: ensamblador, máquina. ¿Por qué sigue siendo útil C? Simple, versátil. Informática aplicada al Medio Ambiente 21 Después de C: POO Años 80: Introduce la programación orientada a objetos (POO) Primer lenguaje: Smalltalk 1972 Objetos con memoria propia Comunicación mediante mensajes Herencia Capacidad de procesamiento Stroustrup propone la extensión del C para incorporar la orientación a objetos: Surge C++ edificado sobre los cimientos del C Años 90: Se afianzan las técnicas de la POO: C++, Aparece JAVA Informática aplicada al Medio Ambiente 22 Introducción a Matlab Se crea a finales de los 70 en University of New Mexico por Cleve Moler. Idea inicial: simplificar el acceso a funciones de análisis numérico en FORTRAN. En 1984 se funda MathWorks y se empieza a comercializar Informática aplicada al Medio Ambiente 23 Introducción a Matlab Acrónimo de MATrix LABoratory Matlab es un entorno de cálculo numérico y un lenguaje de programación. Permite: Fácil manejo de matrices Creación de gráficos 2D y 3D de funciones y datos Implementar funciones, algoritmos y programas Creación de interfaces de usuario Interaccionar con otros lenguajes Informática aplicada al Medio Ambiente 24 Introducción a Matlab Ventajas Interactivo Fácil y rápido de programar Hay muchas funciones disponibles (ToolBoxes) Gráficos Inconvenientes Lento en ejecución Propietario: Se necesita licencia. Opciones libres: Octave/QtOctave y SciLab Informática aplicada al Medio Ambiente 25