Código Intermedio. Compiladores II 1
|
|
|
- Víctor Jiménez Rico
- hace 9 años
- Vistas:
Transcripción
1 Código Intermedio Compiladores II 1
2 Usos del Código Intermedio Múltiples lenguajes y compiladores n+m módulos -> n*m compiladores Optimización Representación de fácil modificación Modelos de generación de código o Máquinas abstractas FAM, G-machine, máquina de Warren Compiladores transportables PASCAL /P-Code, JAVA Interpretación rápida OAKLisp, CLISP Depuración Intérpretes de C u otros lenguajes Compiladores II 2
3 Notación polaca Inversa (postfija) Se utiliza principalmente para la representación de expresiones aritméticas Expresión a notación polaca inversa Algoritmo Representar la expresión en forma de árbol sintáctico Recorrer el árbol en postorden Ejemplo: a+b*c-d Código: a b c * + d d a * b c Compiladores II 3
4 Extensión a instrucciones de control de flujo Ejemplo: Fuente: if <cond> then <instr1> else <instr2> No se puede traducir a: <cond> <instr1> <instr2> If ya que solo se ha de evaluar una de las instrucciones Código generado <cond> etiqueta1 Salta si falso <instr1> etiqueta2 Salta etiqueta1: <instr2> etiqueta2: Código más típico <cond> Salta Si falso Etiqueta1 <Instr1> Salta Etiqueta2 Etiqueta1: <Instr2> Etiqueta2: Compiladores II 4
5 Pros y Contras de la Notación Polaca Inversa Generación de código: Simple No utiliza registros Optimización Es difícil de reordenar ya que hay que considerar el contenido de la pila Interpretación rápida Es muy fácil de interpretar ya que solo necesita una pila Transportable: Si, ya que todos los procesadores implementan una pila. Compiladores II 5
6 n-tuplas En la notación de n-tuplas cada instrucción es una n-tupla. Tripletas <operador>, <operando1>, <operando2> El resultado se asocia al número de tripleta Tripletas indirectas Son tripletas donde el orden de ejecución se especifica a parte. Cuadruplas <operación>, <operando1>, <operando2>, <resultado> Compiladores II 6
7 Tripletas Tripleta: <operador>, <operando1>, <operando2> el resultado se asocia al número de tripleta Ejemplo: W*X+(Y+Z) 1. *, W, X 2. +, Y, Z 3. +, (1), (2) Control de flujo: IF X>Y THEN Z=X ELSE Z=Y+1 1. >, X, Y 2. Saltar si falso, (1), 5 3. =, Z, X 4. Saltar,, , Y, 1 6. =, Z, (5) Problema: La optimización supone mover tripletas y hay que recalcular las referencias Compiladores II 7
8 Tripletas Indirectas Tripletas indirectas. Solucionan el problemas de la reordenación mediante indirección Ejemplo: Fuente: A=B+C*D/E F=C*D Operaciones Tripletas 1. (1) (1) *, C, D 2. (2) (2) /, (1), E 3. (3) (3) +, B (2) 4. (4) (4) =, A, (3) 5. (1) (5) =, F, (1) 6. (5) Compiladores II 8
9 Cuádruplas Cuádrupla: <operación>, <operando1>, <operando2>, <resultado> Ejemplo: (A+B)*(C+D)-E +, A, B, T1 +, C, D, T2 *, T1, T2, T3 -, T3, E, T4 T1, T2, T3, T4 son variables temporales. Las cuádruplas facilitan la aplicación de muchas optimizaciones, pero hay que tener un algoritmo para la reutilización de las variables temporales (reutilización de registros del procesador). Compiladores II 9
10 Fácil creación: Árboles sintácticos abstractos Se crea a partir del árbol sintáctico. Se elimina la información innecesaria. Símbolo no terminales Ejemplo: (a*b)/(c+d) / * + a b c d Compiladores II 10
11 Fácil optimización: Árboles sintácticos abstractos El árbol representa directamente la estructura del lenguaje fuente, y por tanto, las modificaciones que haríamos en el fuente son fáciles de realizar en el árbol. Como el árbol representa la estructura del lenguaje es fácil aplicarle las propiedades de este para optimizar. Propiedad conmutativa. Propiedad asociativa. etc. Compiladores II 11
12 Ejemplos de Árbol en CoSeL Un árbol sintáctico esta formado por las estructuras apply con el contenido: Función: operador raíz Arg(0), Arg(1)... Argumentos del operador Ejemplo: VerArbol(`( Fun f(n)=> if (n<=2) 1 else f(n-2)+f(n-1) )) Fun +- [] +- => +- f +- n +- If_Else +- <= +- n f n f n +- 1 Compiladores II 12
13 Buscar las Variables en un Árbol Fun Variables(arbol)=> { if (TypeP(Symbol,arbol)) [arbol] else if (TypeP(Apply,arbol)) { Var lv=[]; // lista de variables for (i<-arbol:index) lv=lv Variables(arbol.arg(i)); lv } else [] } variables(`( a=b+c; d=a*2;)) [d,a,c,b] Compiladores II 13
14 Buscar las Variables Modificadas en un Árbol Fun VariablesModificadas(arbol)=> { if (ApplyFunP(arbol,`\=,2) && TypeP(Symbol,arbol.arg(0))) { [arbol.arg(0)] } else if (TypeP(Apply,arbol)) { Var lv=[]; for (i<-arbol:index) lv=lv VariablesModificadas(arbol.arg(i)); lv } else [] } VariablesModificadas(`(a=b+c;d=a*2;)) [d,a] Compiladores II 14
15 Eliminar Expresiones Redundantes (NO FUNCIONA CORRECTAMENTE) Type Redundante(variable,expresion); Fun EliminarRedundantes(arbol)=> { Var ExpR=[]; Fun Eliminar(a)=> { Search (r<-expr,r.expresion==a) r.variable else { if (TypeP(apply,a)) { Var na=newapply(a.function,a.nargs); for (i<-a:index) na.arg(i)=eliminar(a.arg(i)); na; } else a; } } Compiladores II 15
16 Eliminar Expresiones Redundantes (NO FUNCIONA CORRECTAMENTE) } Fun Buscar(a)=> { if (ApplyFunP(a,`\=,2)) { Var ne=eliminar(a.arg(1)); ExpR=Redundante(a.Arg(0),ne)::ExpR; << <a.arg(0)> = <ne> >> } else if (TypeP(Apply,a)) { Var na=newapply(a.function,a.nargs); for (i<-a:index) na.arg(i)=buscar(a.arg(i)); na; } else a } Buscar(arbol); Compiladores II 16
17 Eliminar Expresiones Redundantes Ejemplo EliminarRedundantes(`( a=b+c; d=(b+c)*5; e=c+b; ))) Resultado a=b+c; d=a*5; e=c+b; Árbol de la entrada ; +- = +- a b +- c +- ; +- = +- d +- * b +- c = +- e c +- b Árbol del resultado ; +- = +- a b +- c +- ; +- = +- d +- * +- a = +- e c +- b Compiladores II 17
18 Tipo de datos Type Cons(Head,Tail) Type List=Cons [] Listas en CoSeL Construcciones equivalentes [1,2,3]==cons(1,cons(2,cons(3,[]))) Cons(h,t)==h::t [1,2,3]==1::2::3::[] [h1,h2...::t]==h1::h2::...::t Compiladores II 18
19 Operaciones [1,2,3].Head==1 Listas en CoSeL [1,2,3].Tail==[2,3] [1,2,3].Head(0)==1 [1,2,3].Head(1)==2 [1,2]++[2,3]==[1,2,2,3] (append) [1,2] [2,3]==[1,2,3] (unión) [1,2] & [2,3]==[2] (intersección) [1,2] - [2,3]==[1] (resta) Listas por comprensión [x x<-1..5]==[1,2,3,4,5] [x x<-[1,2,3,4,5],x%2==0]==[2,4] Compiladores II 19
20 Árboles Estructura Nodo del arbol: Type apply(function,arg...) Hoja: Cualquier tipo de datos que no sea apply Construcción Árbol en forma de literal `(1+2+A) apply(\+,apply(\+,1,2),a) == 1+2+A Árbol en forma de patrón Var a=10; << 1+A+<A> >> apply(\+,apply(\+,1,a),10) == 1+A+10 Árbol construido directamente Var a=10; apply(`\+,apply(`\+,1,`a),a) apply(\+,apply(\+,1,a),10) == 1+A+10 Compiladores II 20
21 Estructuras de Control Instrucciones de control de flujo Típicas if (condición) instrucción if (condición) sentencia else sentencia switch (selector) {casos} while (condición) instrucción do instrucción while (condición) Break [condición] Continue [condición] No típicas for (generadores) instrucción Search (generadores) instrucción Search (generadores) sentencia else sentencia Found (generadores) sentencia Compiladores II 21
22 Generadores variable <- lista Estructuras de Control variable <- vector : Index variable <- apply : Index variable <- mínimo.. máximo variable <-~ mínimo.. máximo Compiladores II 22
23 Código Enhebrado Es una representación útil para la interpretación independiente de máquina. Código enhebrado directo: El código es una secuencia de direcciones de rutinas que implementan las instrucciones. Algunas rutinas son estándar (Add), pero otras las ha de generar el compilador para que puedan tratar los operandos (Push). Estas últimas limitan la transportabilidad. código Push B Contador de programa virtual Push C Add Pop B Bucle de interpretación For (;;) (*pc++)(); Compiladores II 23
24 Código Enhebrado con Parámetros Código enhebrado indirecto: El código es una secuencia de apuntadores a funciones seguidos de los argumentos que pueda necesitar la función. Contador de programa virtual push b push c add pop c argumento argumento argumento Bucle de interpretación For (;;) (*PC)(); Función void pushliteral() { *--SP=PC[1]; PC=PC+2; } Compiladores II 24
25 Código para máquinas abstractas Un objetivo de los compiladores es ser adaptables y portables a nuevas máquinas. Una de las formas de conseguirlo es con la generación de código para máquinas abstractas. Aplicaciones: Modelos de compilación WAM modelo de compilación de PROLOG G-machine modelo de compilación de lenguajes funcionales con evaluación perezosa. FAM modelo de compilación de lenguajes funcionales con evaluación estricta. Compiladores II 25
26 Código para máquinas abstractas Compiladores portables Compilador ha código intermédio + intérprete. Compilador ha código intermedio + compilador de código intermedio a código máquina n+m módulos -> n*m compiladores Compiladores II 26
27 Resumen Códigos para la ejecución Notación polaca inversa Código enhebrado Códigos para la optimización Árbol sintáctico abstracto Tuplas Tripletas Tripletas indirectas Cuadruplas Códigos para la explicación Códigos de máquinas abstractas Compiladores II 27
Unidad II: Análisis semántico
Unidad II: Análisis semántico Se compone de un conjunto de rutinas independientes, llamadas por los analizadores morfológico y sintáctico. El análisis semántico utiliza como entrada el árbol sintáctico
Generación de Código Intermedio
Generación de Código Intermedio Programación II Margarita Álvarez Generación de código intermedio Con la generación de código intermedio se inicia la tarea de síntesis. Aunque un programa fuente se puede
Tema: Análisis de código intermedio
Compiladores. Guía 8 1 Facultad: Ingeniería Escuela: Computación Asignatura: Compiladores Tema: Análisis de código intermedio Contenido En esta guía se abordarán los conceptos pertenecientes al componente
Unidad VI Generación de Código Intermedio. M.C. Juan Carlos Olivares Rojas
Unidad VI Generación de Código Intermedio M.C. Juan Carlos Olivares Rojas Agenda 6.1 Lenguajes intermedios. 6.2 Notaciones. 6.2.1 Infija. 6.2.2 Postfija. 6.2.3 Prefija. 6.3 Representación de código intermedio.
GENERACIÓN DE CÓDIGO INTERMEDIO ÁRBOLES DE SINTAXIS ABSTRACTA (ASA)
Todos los derechos de propiedad intelectual de esta obra pertenecen en exclusiva a la Universidad Europea de Madrid, S.L.U. Queda terminantemente prohibida la reproducción, puesta a disposición del público
ÍNDICE UNIDAD 2: GENERACION DE CODIGO INTERMEDIO
ÍNDICE UNIDAD 2: GENERACION DE CODIGO INTERMEDIO 2. NOTACIONES 3 2.. PREFIJA.4 2..2 INFIJA....4 2.2.3 POSTFIJA.. 5 2.2 REPRESENTACIONES DE CÓDIGO INTERMEDIO....5 2.2. NOTACIÓN POLACA. 7 2.2.2 CÓDIGO P....8
Un. VI. Generador de código intermedio.
Un. VI. Generador de código intermedio. La administración de la memoria se da en esta etapa. Se debe considerar tanto la memoria estática como dinámica, y en esta se utilizan generalmente pilas. Los lenguajes
Unidad 5 Análisis semántico
61 Unidad 5 Análisis semántico Se compone de un conjunto de rutinas independientes, llamadas por los analizadores morfológico y sintáctico. El análisis semántico utiliza como entrada el árbol sintáctico
Tema 7. Generación de código
Departamento de Tecnologías de la Información Tema 7 Generación de código Ciencias de la Computación e Inteligencia Artificial Índice 7.1 Visión general 7.2 Código de tres direcciones 2 Índice 7.1 Visión
Diseño de Compiladores I. Estructura General de un Compilador
Diseño de Compiladores I Estructura General de un Compilador PROGRAMA FUENTE COMPILADOR SALIDA Mensajes de Error 2 Un compilador es un programa que traduce un programa escrito en lenguaje fuente y produce
Lenguajes y Compiladores Traducción Dirigida por la Sintaxis
Facultad de Ingeniería de Sistemas Lenguajes y Compiladores Traducción Dirigida por la Sintaxis 1 Definición Código Intermedio: estructura de código que posee una complejidad comprendida entre el código
Procesadores de lenguaje Tema 7 Generación de código intermedio
Procesadores de lenguaje Tema 7 Generación de código intermedio Departamento de Ciencias de la Computación Universidad de Alcalá Resumen Representaciones intermedias Código de 3 direcciones Cuádruplas
OPTIMIZACIÓN DE CÓDIGO
OPTIMIZACIÓN DE CÓDIGO INTRODUCCION La finalidad de la optimización de código es producir un código objeto lo más eficiente posible. En algunos casos también se realiza una optimización del código intermedio.
COMPILADORES E INTERPRETES
COMPILADORES E INTERPRETES Análisis semántico: Estudia el significado de la sentencia Procesadores de lenguaje: Convierte un programa fuente hecho en un lenguaje fuente a un programa objeto hecho en un
Lenguajes de programación
Introducción Lenguajes de programación Primera generación: lenguajes máquina Los programas se escriben en código binario 000001011010000000000000 Segunda generación: lenguajes simbólicos Cada instrucción
Compiladores e intérpretes Introducción
Introducción Profesor: Eridan Otto Introducción Perspectiva histórica Motivación Definiciones Componentes y fases de un compilador 1 Introducción Definiciónes básicas Traductor: desde un punto de vista
Semántica: principales usos. Semántica: principales enfoques. Semántica Operacional. Sintaxis abstracta de un lenguaje (sujeto) Semántica Operacional
Semántica: principales enfoques Semántica Operacional Se define el significado mediante una máquina abstracta (con estados) y secuencias de cómputos sobre dicha máquina Semántica Denotacional El significado
AMBIENTES DE COMPILACION
AMBIENTES DE COMPILACION Los compiladores a menudo producen como resultado del análisis semántico, una forma de representación intermedia del código fuente. Hoy en día, es cada vez más común que, en ambientes
Tema: Análisis Léxico
Compiladores. Guía 2 1 Facultad: Ingeniería Escuela: Computación Asignatura: Compiladores Tema: Análisis Léxico Contenido En esta guía se dará a conocer la manera en que un compilador realiza el análisis
Tema 1 INTRODUCCIÓN A LOS LENGUAJES DE PROGRAMACIÓN
Tema 1 INTRODUCCIÓN A LOS LENGUAJES DE PROGRAMACIÓN - Introducción - Sintaxis - Semántica básica - Tipos de datos - Expresiones y enunciados - Procedimientos y ambientes - Tipos abstractos de datos y módulos
Todo programa en 'C' consta de una o más funciones, una de las cuales se llama main.
LENGUAJE C CARACTERISTICAS DEL LENGUAJE 'C' El lenguaje 'C' se conoce como un lenguaje compilado. Existen dos tipos de lenguaje: interpretados y compilados. Los interpretados son aquellos que necesitan
GENERACIÓN DE CÓDIGO INTERMEDIO CÓDIGO DE TRES DIRECCIONES
Todos los derechos de propiedad intelectual de esta obra pertenecen en exclusiva a la Universidad Europea de Madrid, S.L.U. Queda terminantemente prohibida la reproducción, puesta a disposición del público
PROCESADORES DE LENGUAJE EXAMEN FINAL 8-JUNIO-07
PROCESADORES DE LENGUAJE EXAMEN FINAL 8-JUNIO-07 1. En qué método de análisis sintáctico puede suceder que en la construcción del árbol de derivación de las posibles expansiones de un símbolo no terminal
Procesadores de Lenguajes. Análisis sintáctico. Gramáticas libres de contexto
Procesadores de Lenguajes Ingeniería Técnica superior de Ingeniería Informática Departamento de Lenguajes y Sistemas informáticos Análisis sintáctico Gramáticas libres de contexto Javier Vélez Reyes [email protected]
Uno de los conceptos más útiles en ciencias de la computación es la pila.
23. PILA. (Stack). Tipos de Datos Abstractos. 23.1 Conceptos. Uno de los conceptos más útiles en ciencias de la computación es la pila. Una pila es una colección ordenada de elementos de igual tipo, en
Análisis semántico Tabla de símbolos, chequeo de tipos y representaciones internas
Análisis semántico Tabla de símbolos, chequeo de tipos y representaciones internas Análisis semático c 2001 José Fortes Gálvez p.1 Análisis?... semántico? La semántica corresponde al significado asociado
Construyendo Programas más Complejos
Arquitectura de Ordenadores Construcciones de Alto Nivel en Ensamblador Abelardo Pardo [email protected] Universidad Carlos III de Madrid Departamento de Ingeniería Telemática Construyendo Programas más
Tiempo de Compilación. Programa fuente. Secuencia. de caracteres. Scanner. Secuencia. de símbolos Parser. Compilador.
ORGANIZACIÓN DE LA MEMORIA EN TIEMPO DE EJECUCIÓN Compilador Tiempo de Compilación Programa fuente Secuencia de caracteres Scanner Secuencia de símbolos Parser Árbol sintáctico Analizador semántico Generador
Introducción general al Lenguaje C (2010/2011)
Luis Valencia Cabrera [email protected] (http://www.cs.us.es/~lvalencia) Ciencias de la Computacion e IA (http://www.cs.us.es/) Introducción general al Lenguaje C (2010/2011) Universidad de Sevilla Índice
GENERACIÓN DE CÓDIGO INTERMEDIO EJEMPLOS PARA DISTINTAS ESTRUCTURAS DE DATOS
Todos los derechos de propiedad intelectual de esta obra pertenecen en exclusiva a la Universidad Europea de Madrid, S.L.U. Queda terminantemente prohibida la reproducción, puesta a disposición del público
Controla el flujo de tokens reconocidos por parte del analizador léxico. 4.2 Introduccion a las gramaticas libres de contexto y arboles de derivacion
UNIDAD IV Analisis Sintactico 4.1 Introduccion Sintaxis significa estructura del orden de las palabras en una frase. La tarea del analisis sintactico es revisar si los símbolos aparecen en el orden correcto
CÓMO DESARROLLAR Y PROBAR PROGRAMAS?, COMPRUÉBALO!
CÓMO DESARROLLAR Y PROBAR PROGRAMAS?, COMPRUÉBALO! AUTORÍA MARÍA CATALÁ CARBONERO TEMÁTICA PROGRAMACIÓN ETAPA CICLO MEDIO Y SUPERIOR DE INFORMÁTICA Resumen A la hora de realizar un programa en cualquier
Compiladores: Análisis Semántico. Pontificia Universidad Javeriana Cali Ingenieria de Sistemas y Computación Prof. Gloria Inès Alvarez V.
Compiladores: Análisis Semántico Pontificia Universidad Javeriana Cali Ingenieria de Sistemas y Computación Prof. Gloria Inès Alvarez V. Verificaciòn de tipos Se puede hacer en forma Estàtica: en tiempo
GENERACIÓN DE CÓDIGO
GENERACIÓN DE CÓDIGO INTRODUCCION La generación de código es la fase más compleja de un compilador, puesto que no sólo depende de las características del lenguaje fuente sino también de contar con información
Índice general 7. Presentación 15
ÍNDICE GENERAL Índice general 7 Presentación 15 1. Introducción 19 1.1. Antecedentes históricos de la computación................... 19 1.2. Definiciones previas............................... 24 1.3.
Java para no Programadores
Java para no Programadores Programa de Estudio Java para no Programadores Aprende a programar con una de las tecnologías más utilizadas en el mercado de IT. Este curso está orientado a quienes no tienen
Programación 1 Tema 2. Lenguaje de programación y ejecución de un programa
Programación 1 Tema 2 Lenguaje de programación y ejecución de un programa Índice Lenguaje de programación Símbolos Sintaxis Semántica Computador Ejecución de un programa Sistema operativo, entorno de programación
Teoría de autómatas. Un enfoque práctico. Recortables. Thelma Cantú María Gpe. Mendoza
Teoría de autómatas. Un enfoque práctico Recortables Thelma Cantú María Gpe. Mendoza 1.1 Búsqueda de lenguajes Alumno: 1 Nombre del lenguaje Alfabeto: Dónde se utiliza? Cuál es el beneficio para la humanidad?
Análisis semántico Tabla de símbolos, chequeo de tipos y representaciones internas
Análisis semántico Tabla de símbolos, chequeo de tipos y representaciones internas Análisis semático v1.2 c 2005 José Fortes Gálvez p.1 Análisis?... semántico? La semántica corresponde al significado asociado
Java para no Programadores
Java para no Programadores Programa de Estudio Java para no Programadores Aprende a programar con una de las tecnologías más utilizadas en el mercado de IT y comienza tu camino como desarrollador Java.
Estructura de Datos. Temario Unidad VI. Árboles Árboles Binarios
Estructura de Datos Árboles Árboles Binarios Temario Unidad VI 6.1 Definición y operaciones 6.2 Implementación 6.3 Recorrido en Árboles Binarios 6.4 Árboles AVL y su implementación 6.5 Árboles n-arios
UNIDAD 2. ESTRUCTURAS DE DATOS SECUENCIALES. 1. Pilas (Stacks)
UNIDAD 2. ESTRUCTURAS DE DATOS SECUENCIALES 1. Pilas (Stacks) Una pila es una coleccion de elementos en la que sólo se pueden insertar y eliminar datos por uno de los extremos de la lista. Al igual que
Lenguajes y Compiladores Introducción. Compiladores 1
Facultad de Ingeniería de Sistemas Lenguajes y Introducción 1 Objetivos Conocer los fundamentos de construcción de en todas sus fases, presentando los conceptos básicos, definiciones formales, técnicas
Árboles de Decisión Árboles de Sintaxis
Árboles de Decisión Árboles de Sintaxis Estructuras de Datos Andrea Rueda Pontificia Universidad Javeriana Departamento de Ingeniería de Sistemas Árboles de Decisión Árbol de Decisión Forma gráfica de
Lenguaje de programación. COMPILADORES Unidad I: Introducción al proceso de compilación
COMPILADORES Unidad I: Introducción al proceso de compilación Flor Prof. Flor Narciso GIDyC-Departamento de Computación LABSIULA-Escuela de Ingeniería de Sistemas Facultad de Ingeniería Universidad de
Fundamentos PHP. El término puntuación nos referimos a la sintaxis usada en PHP para la terminación de una línea de código (;)
Tags Fundamentos PHP La Sintaxis de PHP se deriva de muchos lenguajes de programación principalmente de C pero Perl también ha tenido mucha influencia en esta sintaxis Con las últimas incorporaciones agregadas,
UNIDAD V. Analisis Semantico. 5.1 Introduccion. Analizador Semántico. Verifica que el significado de las construcciones del lenguaje tengan sentido.
UNIDAD V Analisis Semantico 5.1 Introduccion Analizador Semántico. Ejemplo: Verifica que el significado de las construcciones del lenguaje tengan sentido. Tareas del analizador semántico: 1) Comprobación
Programación de Sistemas. Unidad 6. Macro Procesador
Programación de Sistemas Unidad 6. Macro Procesador Contenido Introducción Algoritmos y Estructuras Características Independientes de la Máquina Opciones de Diseño Introducción Introducción Una macro instrucción,
Tema 2 Conceptos básicos de programación. Fundamentos de Informática
Tema 2 Conceptos básicos de programación Fundamentos de Informática Índice Metodología de la programación Programación estructurada 2 Pasos a seguir para el desarrollo de un programa (fases): Análisis
Elementos léxicos del lenguaje de programación Java
Elementos léxicos del lenguaje de programación Java Elementos léxicos del lenguaje de programación Java Palabras reservadas Identificadores Literales Operadores Delimitadores Comentarios Apéndices Operadores
Introducción a OCaml. October 19, 2015
Introducción a OCaml October 19, 2015 OCaml: introducción Es un dialecto de ML. Lenguaje de programación funcional. Fuertemente tipado. Con inferencia de tipos. Polimórfico. [Página oficial: http://www.ocaml.org/
LENGUAJES DE PROGRAMACIÓN. Solución al Ejercicio de Autocomprobación 1
Solución al Ejercicio de Autocomprobación 1 PREGUNTA 1 (1 punto) Señale razonadamente la veracidad o falsedad de las afirmaciones siguientes: A. La diferencia fundamental entre los lenguajes ensamblador
FASES DE UN COMPILADOR
FASES DE UN COMPILADOR PROGRAMA FUENTE analizador léxico analizador sintáctico administrador analizador semántico manejador de la tabla generador de código intermedio de errores de símbolos optimizador
TP 3: intérprete de C en LISP (alias máquina virtual de C en LISP )
TP 3: intérprete de C en LISP (alias máquina virtual de C en LISP Introducción Se deberá programar un intérprete de C en LISP. El código que ingresará al intérprete tendrá ciertas restricciones: Se utilizará
INTRODUCCION AL LENGUAJE C PARA SISTEMAS EMBEBIDOS
INTRODUCCION AL LENGUAJE C PARA SISTEMAS EMBEBIDOS QUE ES UN SISTEMA EMBEBIDO? Es un sistema electrónico que está contenido dentro de un dispositivo electromecánico y es diseñado para realizar una aplicación
INDICE Parte I Algoritmos y herramientas de programación Capitulo 1. Computadoras y lenguajes de programación Actividades de Programación Resueltas
INDICE Prologo a la tercera edición xiii Prologo a la segunda edición xxvii Parte I Algoritmos y herramientas de programación Capitulo 1. Computadoras y lenguajes de programación 3 1.1. Organización de
Examen de Procesadores de Lenguaje
Apellidos: Nombre: Dni: Examen de Procesadores de Lenguaje Junio de 2007 (2 horas y 45 minutos) Instrucciones Entrega esta hoja, rellenada con tus datos, junto a tu examen cuando lo entregues. Ten en cuenta
Estructuras de Datos. La pila es un objeto dinámico en constante cambio.
21 Capítulo 2. LA PILA (STACK). 2.1 Definición y ejemplos. Una pila es un conjunto ordenado de elementos en el cual se pueden agregar y eliminar elementos de un extremo, el cual es llamado el tope de la
Componentes Básicos. InCo. InCo Componentes Básicos 1 / 28
Componentes Básicos InCo InCo Componentes Básicos 1 / 28 Modelo de Computación Vemos al computador como un procesador de datos. +------------+ Entrada ===> Computador ===> Salida +------------+ InCo Componentes
Definición de la sintaxis (1) Definición de la sintaxis (2) Definición de la sintaxis (3)
Definición de la sintaxis (1) Gramática independiente del contexto: tiene cuatro componentes: Un conjunto de componentes léxicos, denominados símbolos terminales. Un conjunto de no terminales. Un conjunto
Tema: Análisis Semántico
Compiladores. Guía 7 1 Facultad: Ingeniería Escuela: Computación Asignatura: Compiladores Tema: Análisis Semántico Contenido En esta guía se desarrollará una tabla de símbolos y se asociará al analizador
UNIDAD IV Programación Funcional. Lic. Jesús Germán Andrés PAUTSCH - FCEQyN - UNaM
UNIDAD IV Programación Funcional Porqué? 2 Introducción Porque aprender programación funcional? - Recursión - Abstracción funcional - Funciones de primer orden Estos conceptos se han incorporado en la
Programación Web Tema 3.2 Java Script Estructura del Lenguaje. Ramón Alcarria ETSI en Topografía, Geodesia y Cartografía - UPM
Programación Web Tema 3.2 Java Script Estructura del Lenguaje Miguel Ángel Manso Emerson Castañeda Ramón Alcarria ETSI en Topografía, Geodesia y Cartografía - UPM Contenido Variables Operadores Estructuras
Tema II: Introducción al Lenguaje Funcional
Tema II: Introducción al Lenguaje Funcional Características de Haskell Lenguaje funcional de o. superior fuertemente tipificado. Clasifica los entes de un programa en: objetos (constantes y funciones)
LENGUAJE. Tema 2 Elementos de un programa
LENGUAJE Tema 2 Elementos de un programa ELEMENTOS DE UN PROGRAMA Comentarios. Identificadores. Constantes. Variables. Operadores. Sentencias o instrucciones. COMENTARIOS Los comentarios en C pueden ocupar
Estructuras de datos y algoritmos
Estructuras de datos y algoritmos 1. Introducción 2. Estructuras de datos lineales 3. Estructuras de datos jerárquicas 4. Grafos y caminos 5. Implementación de listas, colas, y pilas 6. Implementación
Estructuras de Datos
Estructuras de Datos. Tema 1. Programación Imperativa de Computadores Tema 2. Fundamentos de Complejidad Algorítmica Tema 3. Estructuras de datos jerárquicas Tema 4. concepto y especificación de Tipos
Unidad I Introducción a la programación de Sistemas. M.C. Juan Carlos Olivares Rojas
Unidad I Introducción a la programación de Sistemas M.C. Juan Carlos Olivares Rojas Agenda 1.1 Qué es y que estudia la programación de sistemas? 1.2 Herramientas desarrolladas con la teoría de programación
Reconstrucción de Código. Joxean Koret
Reconstrucción de Código Joxean Koret Guión Introducción Fundamentos Construcciones típicas Variables Llamadas a funciones Sentencias condicionales Bucles Ejemplos Durante la charla se irá reconstruyendo
Concepto de compilador Intérprete Fases de un Compilador Herramientas de construcción de Compiladores
18:55 1 2 Temas Concepto de compilador Intérprete Fases de un Compilador Herramientas de construcción de Compiladores Objetivo Que el estudiante logre conocer, comprender y manejar conceptos y técnicas
AGENDA Curso Java Básico
2012 AGENDA Curso Java Básico México, D.F. 27 de enero del 2012 A quien corresponda. Presente. Por medio de la presente nos permitimos hacerte llegar nuestra agenda del curso de Java Básico que tomaras
COMPILADORES. Tema 4. Análisis semántico
COMPILADORES Tema 4. Análisis semántico Presenta: David Martínez Torres Universidad Tecnológica de la Mixteca Instituto de Computación Oficina No. 37 [email protected] Contenido 1. Funcionalidad del
RECORRIDO EN ARBOLES
RECORRIDO EN ARBOLES Orlando Arboleda Molina Escuela de Ingeniería de Sistemas y Computación de La Universidad del Valle 16 de septiembre de 2008 Contenido Recorrido en árboles Definición Recorrido en
2. DISEÑO DEL REPERTORIO DE INSTRUCCIONES MÁQUINA
2. DISEÑO DEL REPERTORIO DE INSTRUCCIONES MÁQUINA 2.1. Tipos de juegos de instrucciones 2.2. Compiladores, repertorio de instrucciones y rendimiento 2.3. Computadores de juego reducido de instrucciones:
Introducción. El proceso de traducción
Traductores y compiladores bajo + de abstracción 1945 1950 1968 1970 1990 11100110 0001 0110 10101001 1100 0011 11000011 1101 1100 MOVE AX #2 MOVE BX #3 MUL CX AX BX Fact = 1; For i:=0 to 10 fact := fact
INDICE. Prólogo de la Segunda Edición
INDICE Prólogo de la Segunda Edición XIII Capitulo 1. Algoritmos y Programas 1 1.1. Los sistemas de procesamiento de la información 2 1.2. Concepto de algoritmo 4 1.2.1. Características de los algoritmos
INTRODUCCIÓN AL ANÁLISIS ASCENDENTE. V id asig num. La siguiente figura muestra la tabla de análisis SLR de la gramática anterior:
Procesadores de lenguajes Ejercicios del Tema 4 INTRODUCCIÓN AL ANÁLISIS ASCENDENTE Ejercicio 4.1 Considere la siguiente gramática: D T L pyc T float T int L V L L coma V V id V id asig num La siguiente
Tema: Autómata de Pila
Facultad: Ingeniería Escuela: Computación Asignatura: Compiladores 1 Tema: Autómata de Pila Contenido La presente guía aborda los autómatas de pila, y se enfoca en la aplicación que se le puede dar a estas
Introducción a la. Programación con
Introducción a la Programación con C Objetivo El alumno comprendera los conceptos sobre cuales se rige la programación estructurada mediante una base teórica y un conjunto de prácticas, enfocando dichos
Análisis semántico: Comprobación de tipos
Análisis semántico: Comprobación de tipos Expresiones de tipos, sistemas de comprobación de tipos, equivalencia, resolución de sobrecargas y unificación. Introducción Objetivo de comprobación estática:
Lección 2 Introducción al lenguaje C
Lección Introducción al lenguaje C Decimal Binario Hexadecimal A B C D E F Octal Equivalencia entre decimal, binario, hexadecimal y octal. Código ASCII (American Standard Code for Information Interchange)
ALGORITMO. Podemos encontrar muchas definiciones de algoritmo en los textos de programación, todas ellas muy similares:
Nuestra herramienta mental más importante para competir con la complejidad es la abstracción. Por tanto, un problema no deberá considerarse inmediatamente en términos de instrucciones de un lenguaje, sino
Tipos algebraicos y abstractos. Algoritmos y Estructuras de Datos I. Tipos algebraicos
Algoritmos y Estructuras de Datos I 1 cuatrimestre de 009 Departamento de Computación - FCEyN - UBA Programación funcional - clase Tipos algebraicos Tipos algebraicos y abstractos ya vimos los tipos básicos
16 Análisis sintáctico I
2 Contenido Recordando la estructura de un compilador Recordando el análisis léxico l análisis sintáctico Comparación con el análisis léxico l Rol del Parser Lenguajes de programación Gramáticas structura
PROGRAMA: COMPUTACION I
UNIVERSIDAD NACIONAL EXPERIMENTAL DEL TACHIRA VICERECTORADO ACADÉMICO DECANATO DE DOCENCIA DEPARTAMENTO DE INGENIERÍA INFORMÁTICA 1 PROGRAMA: COMPUTACION I Código 0415102T Carrera: Ingeniería Informática
Estructuras de Control
Algorítmica y Lenguajes de Programación Estructuras de Control Estructuras de Control. Introducción Hasta ahora algoritmos han consistido en simples secuencias de instrucciones Existen tareas más complejas
Compiladores e Intérpretes
Departamento de Cs. e Ingeniería de la Computación Universidad Nacional del Sur Compiladores e Intérpretes Proyecto N 1 Sintaxis de MiniJava Segundo Cuatrimestre de 2018 1. Introducción Este documento
