Compiladores

Disponível somente no TrabalhosFeitos
  • Páginas : 4 (970 palavras )
  • Download(s) : 0
  • Publicado : 27 de outubro de 2013
Ler documento completo
Amostra do texto










COMPILADORES E COMPUTABILIDADE
















ETAPAS DE CONSTRUÇÃO DO COMPILADOR

COMPILADOR
Um compilador é um programa de computador que, a partir de umcódigo fonte escrito em uma linguagem compilada, cria um programa semanticamente equivalente, porém escrito em outra linguagem, código objeto.
Normalmente, o código fonte é escrito em uma linguagem deprogramação de alto nível, com grande capacidade de abstração, e o código objeto é escrito em uma linguagem de baixo nível, como uma sequência de instruções a ser executada pelo microprocessador.
Oprocesso de compilação é composto de análise e síntese. A análise tem como objetivo entender o código fonte e representá-lo em uma estrutura intermediária. A síntese constrói o código objeto a partirdesta representação intermediária.
A análise pode ser subdividida ainda em análise léxica, análise sintática, análise semântica e geração de código intermediário. É também conhecida como front-end. Asíntese pode ter mais variações de um compilador a outro, podendo ser composta pelas etapas de optimização de código e geração de código final (ou código de máquina), sendo somente esta última etapa éobrigatória. É também conhecida como back-end.

FASES DA COMPILAÇÃO

ANÁLISE LÉXICA
A análise léxica é a primeira fase do compilador. A função do analisador léxico, também denominado scanner, éler o código fonte, caractere a caractere, buscando a separação e identificação dos elementos componentes do programa-fonte, denominados símbolos léxicos ou tokens. É também de responsabilidade destafase a eliminação de elementos “decorativos” do programa, tais como espaços em branco, marcas de formatação de texto e comentários. Existem disponíveis uma série de geradores automáticos deanalisadores léxicos, como por exemplo, o lex. O objetivo dos geradores automáticos é limitar o esforço de programação de um analisador léxico especificando-se apenas os tokens a serem reconhecidos....
tracking img