quinta-feira, 29 de julho de 2010
Busca  
Porta 80 Web Hosting
 :: Acessibilidade
Ir para conteúdo principal: ALT + 1
 :: Participe
Seja um autor de CD/DVD de Treinamento
Publique um artigo
Publique uma oportunidade
Publique uma notícia
Publique um curso
Publique uma dica
Publique um código
 :: Informativo
Receba nossos informativos por e-mail.
E-mail:   
 
Digite a palavra abaixo:  
 
 
 :: Oportunidades
Cadastrar oportunidades
Gerenciar suas oportunidades
Cadastrar nova empresa
 :: Especiais
Básico de C++
C++ Builder
Curso ASP.NET 3.5 em VB.NET e C#
Guia Prático de HTML
Testes com Visual Studio Team System 2008
 :: Desenvolvimento
ActionScript
ADO.NET
ASP
ASP.NET
Automação Comercial
C#
C/C++
Coldfusion
CSS
Delphi
Disp. Móveis
HTML
Java
Javascript
LSL (Second Life)
Modelagem
PHP
Python
Sharepoint
Silverlight
SQL
VBA (Office)
Visual Basic
Visual Basic .NET
Visual Fox Pro
WCF/WPF
Web Services
XML
 :: Infra
BizTalk Server
CRM
Exchange Server
ForeFront / Antigen / IAG
Interoperabilidade
ISA Server
Linux
MOF
MS Dynamics CRM
Network
OCS / LCS
Outlook
Powershell e Scripts
Redes
Segurança
System Center e Gerenciamento
Virtualização
Windows
Windows Server
 :: Banco de Dados
Access
Caché
Firebird
Interbase
MySQL
Oracle
SQL Server
Sybase
 :: Gerência
Arquitetura
Ciclo de Vida de Desenvolvimento
Controle de Versão
Estimativas
Metodologias
MOF
Qualidade e Testes
 :: Design
Corel
Flash
Photopaint
Photoshop
 :: Livros
Análise Sistemas
Aplicativos
Banco de Dados
Certificação
Design e CAD
Gerência
Hardware
Internet
Programação
Programação Web
Rede
Segurança
Servidores
Sistemas Operacionais
 :: CDs/DVDs
Desenvolvimento
Infra
Design
 :: E-Books
.NET 2.0 (VS 2005)
.NET 1.1 (VS 2003)
SQL Server
Excel 2007
Excel 2003
Access 2003
ASP 3.0
Delphi
Java
Artigos
Compiladores: Revisão dos Princípios, Técnicas e Ferramentas
Por: Nilton Sango Guimarães
[Entre em contato com o autor ]
Analista de TI / Professor Universitário. Pós-Graduado em MBA em Tecnologias ERP, Graduado em Ciência da Computação. Atua no Levantamento das informações para Tomadas de Decisão e Administração de TI.
Feed de artigos.
Feed de artigos deste autor.
Gere seu feed personalizado  
Compiladores: Revisão dos Princípios, Técnicas e Ferramentas
Publicado em: 18/01/2008

1. Resumo:

O Avanço da tecnologia e dos sistemas informatizados trouxe a toda comunidade de TI uma completa automação nos processos de desenvolvimento de softwares. Hoje, novas tecnologias estão sendo lançadas e o processo de programação e desenvolvimento de sistemas para computadores tornou-se bem mais ágeis. Contudo, se esquecemos que para o código fonte, desenvolvido pelos programadores, se tornar um código objeto, temos o integrador chamado de Compilador, que nada mais é que um programa que converte código fonte em código objeto. Foi pensando nisso, que esse artigo tratará de um resumo abordando sobre o tema: Compiladores. Estarei disponibilizando 3 exemplos de analisadores (léxico semântico e sintático).

2. Definições:

-          Tradutor – São programas que convertem linguagem fonte em qualquer outra linguagem de máquina equivalente.

-          Compilador – São tradutores que mapeiam instruções em linguagem de máquina, viabilizando seu tempo de execução. Possuem facilidade em manipulação, ágeis, corrigem erros, comentários, otimizam e geram códigos intermediários.

-          Montador – Converte textos em mneumônios

-          Interpretadores – interpretam trechos de comandos linha a linha, encontrando o ponto exato de um erro no programa. São mais demorados.

-          Filtros, pré-processador, pré-compilador – São tradutores que efetuam conexões em alto nível.

-          Macro Assembly – São tradutores que convertem linguagem simbólica em linguagem de maquina

3. Gerações de computadores:

-          1ª Geração – Linguagem simbólica – linguagens de baixo nível.

-          2ª Geração – Linguagem de máquina – linguagem de baixo nível.

-          3ª Geração – Linguagem orientada ao usuário – são as linguagens procedimentais: Pascall, C, Clipper.

-          4ª Geração – São as linguagens orientadas as aplicações: Databasic.

-          5ª Geração – São as linguagens orientadas a IA. Linguagens do conhecimento – Prolog.

4. Compiladores:

Gerador da TS – É uma estrutura de registros organizada por campos onde são armazenados os dados e informações de variáveis e constantes.

Tratador de erros – Ele verifica aonde se encontra o erro a ser tratado. O tratador de erros depende da análise empregada.

Analisador Léxico – O tratador de erros do analisador léxico não reconhece caracteres especiais. Quando ele encontra, ele remove o caractere especial, insere um novo caractere e altera o caractere errado pelo certo.

Analisador Sintático – o tratador de erros não para a execução, quando encontra um erro e trata o erro e continua a execução. O tratador de erros do analisador sintático ele trata os erros nas seguintes condições.

1.    Método do Desespero – É o mais simples porque trata somente um erro por linha. Encontrando o erro, ele descarta o símbolo lido.

2.    Recuperação de Frases – Faz se a correção local, encontrando o erro troca-o por um token voltando a ser executado o tratador de erros.

3.    Produção de Erros – suponhamos que naquela frase exista o erro, tratamos.

4.    Correção global – É uma técnica teórica, faz-se a correção global.

Analisador Semântico – Verifica o tipo de variáveis, se elas são compatíveis com a declaração de escopo, que estão declaradas na TS; verifica o escopo através de hierarquias empilhando os escopos e desempilhando os escopos, se ao final do programa a pilha resultar em NULL (programa ok). Organiza em arvores de derivação.

-          Gerador de código intermediário – utiliza a representação interna do analisador léxico e fornece como saída uma seqüência de códigos. Suas vantagens: - facilidade na otimização do código; - útil na passagem para o código objeto. Desvantagem: é mais uma etapa na compilação do programa.

-          Otimizador de Código – ele otimiza o código fazendo com que torne mais rápido com menor tamanho em menor tempo de execução. Ele deve preservar a semântica do programa e suas alterações devem conceder leveza e rapidez ao algoritmo.

-          Suas aplicações são:

o    Eliminação de repetições de subprogramas;

o    Eliminação de código morto;

o    Eliminação  de cópias desnecessárias; 

o    Otimizador de laços e movimentação do código.

Trabalham com 2 gerações:

-          Top down (descendente)

-          Bottom up (redutiva)

1.    Top down – a partir de um símbolo inicial vai se construindo a arvore até atingir suas falhas.

Método de tentativa e erro – é o mais simples e o primeiro; é ineficiente; o analisador verifica até encontrar o erro, encontrando trata e tenta de novo;

Analise preditiva LLK – Contam-se quantos K até o ponto em que se deseja chegar.

2.    Bottom-up – a partir das folhas de ramificação faz se analise até chegar ao símbolo inicial. Vai reduzindo da direita para a esquerda. É o inverso da top-down.

5. Máquinas Abstratas

São máquinas teóricas que fornecem condições para a execução de um programa. Trabalham com linguagens em códigos de instruções teóricas.

6. Síntese do Programa Objeto

-          Possuem 3 aspectos importantes para seus requisitos:

1 – O código gerado deve ser fácil e de alta qualidade;

2 – O programa deve executar efetivamente;

3 – Deve ter uso efetivo na CPU;

-          Aspectos na representação do projeto do programa objeto:

1 – Forma do código objeto:

- Linguagem absoluta (armazenam variáveis em áreas fixas tornando o processo mais rápido, contudo, essas regiões podem ser bloqueadas);

-  Relocável (permite que o compilador execute subprogramas);

- Assembly (trabalham com instruções de máquina – 3 endereços).

2 – Alocação de registradores;

3 – Determinação do tipo de avaliação  - Permite a escolha da ordem  de execução de instruções no programa.

4 – Seleção de instruções de máquina – a escolha de conjuntos de instruções pode determinar numa agilidade e facilidade melhor.

7. Ambiente de Tempo de Execução

São as ações que precisam ocorrer em tempo de execução para implementar o programa.

Gerencia de Memória - Refere-se à alocação e a liberação de memória para variáveis e constantes em tempo de execução e compilação.

8. Estratégias de Alocação de Memória

Organização:                             código objeto

                                                         Área de dados estática

                                                         Pilha

                                                         HEAP

Heap – Área de dados  alocados controlada pelo programa;

Pilha – Armazena dados locais de procedimentos. Armazena o RA

A alocação de memória pode ser:

-          Alocação Estática – se o tipo de variável é conhecido durante o tempo de execução e seu valor não é alterado no tempo de compilação, reserva-se memória de forma estática.

-          Alocação em Pilha – são armazenado dinamicamente os dados locais de parâmetros e procedimentos.

-          Alocação Dinâmica – para estruturas de dados referenciados por ponteiros. Estas áreas são alocadas e liberadas pelo HEAP.

8.1. Alocação de memória em Pilha

-          Utiliza para os procedimentos – para cada chamada armazena os dados e informações de variáveis  num registro de ativação – RA. Em cada retorno desempilha um RA.

8.2.       Passagem de Parâmetro

 A comunicação entre dados e procedimentos é feita através de variáveis globais ou de parâmetros.

Os principais métodos são:

-          Por valor – os parâmetros são avaliados  e seus valores são passados para o procedimento chamado. Pode ser implementado como:

1 – um parâmetro formal é tratado como um nome local de maneira que sua memória é armazenada num RA.

2 – Os parâmetros reais são avaliados e armazenado  seus valores na memória reservada para os parâmetros formais.

-          Por endereço – São passados os endereços de cada parâmetro real.

8.3.       Alocação Dinâmica

São armazenados os dados locais de procedimentos e estados da CPU. São alocados no HEAP. A alocação pode ser: Explicita – o programador deve armazenar e liberar espaços de memória através de instruções de linguagens de máquina.

Implícita – o programador não se preocupa com alocação de variáveis, é declarado à variável e automaticamente reservado o seu espaço de memória; quando executado esta variável é automaticamente liberado seu espaço.

9.     Geração de Código

-          ASPECTOS importantes:

1 – Implicações de hardware – o compilador deve escolher o tipo adequado de conjuntos de instruções.

2 – Tratamento de variáveis – são acrescentados na TS informações adicionais sobre informações de uma determinada variável.

3 – Tratamentos de estruturas de programação – São incrementados 2 novas instruções:  - testar o valor da condição;  - verificar o salto, se ela está saindo de um determinado ponto e atingindo outro bloco de comando.                           

4 – Tratamento de Sub-rotinas – Retornam para a posição de onde ocorreu o desvio.

10.  Bibliografia

AHO, A. V., LAM, M. S., SETHI, R.  Compiladores Princípios, Técnicas e Ferramentas. 2ª Ed. Pearson, 2007.

11.  Anexos

Baixe os anexos, clicando aqui.





O que você fará com o Visual Studio 2010?



 

Inclua um comentário sobre o artigo Topo
Elogios e críticas são muito bem vindos, porém o comentário deve ter referência ao artigo em pauta.
O portal e o autor agradecem.
Nome:    
E-mail:      
Comentários:    
Digite a palavra abaixo:  
Para dúvidas técnicas, NÃO UTILIZE ESTE ESPAÇO, utilize nosso fórum de discussão.
http://linhadecodigo.com.br/cs2/forum
 
Comentários sobre o artigo Ver Todos comentários
Achei a materia surper legal, porem quaria um software de compiladores.
Quem enviou: Gisele Bano
Postado em: 20/3/2009 0:00:00
me passa seu e-mail que passo alguns códigos fontes de analisadores léxicos que eu desenvolvi na época de graduação.

Anexo ao artigo tem outros exemplos...Você baixou eles?
Quem enviou: Nilton Guimarães
Postado em: 24/3/2008 0:00:00
Bom Dia !
Sou iniciante em c++, preciso fazer um analisador lexico simples, e minha dificuldade está no código fonte, como n sei nem começar em c++, estou no ponto zero, alguem poderia me ajudar?
Quem enviou: Rafael
Postado em: 18/3/2008 0:00:00
Meu trabalho de graduação foi desenvolver um compilador, assim posso dizer que este artigo esta muito rico em informações, das quais muitas eu naum conhecia... mto bom
Quem enviou: Igor Macile
Postado em: 22/1/2008 0:00:00
Outros artigos do autor Topo
Abordagem Estrutural sobre Arquitetura e Organização de Computadores
Funcionalidades Estratégias em Sistemas ERP - Enterprise Resource Planning
Active Directory - Serviço de Diretório em Redes Corporativas
Artigos relacionados Topo
Reutilizando Código Nativo no .NET
Polimorfismo estático (C++)
Desenvolvedor Profissional. Será?
Sobrecarga de função às avessas
Proteção dos membros protected
Ponteiros de método: conceito fundamental
O que acontece quando o contador estoura
Como pegar o sizeof de um membro de um struct...
Classe do dia: HResult
Bugs difíceis de achar
Drag and drop no Cpp Builder - parte 6
Desenhando em Cpp Builder - parte 5
Gerenciamento de janelas em Cpp Builder - parte 4
Conceitos básicos na programação com Cpp Builder - parte 3
Interação entre controles no Cpp Builder - parte 2
Conhecendo o Cpp Builder - parte 1
Aquisição de recurso é inicialização
A inteligência do if
Instalando o Dev-C++ com MinGW e GDB atualizados
Por que aprender C/C++?
Básico de C++: Diretivas de pré-processador
C++ Tutorial: 5.4: Advanced Class Type-casting
Básico de C++: Tratamento de exceções
Básico de C++: Namespaces
Básico de C++: Templates
.Net Framework 2.0: Delegates
Básico de C++: Membros Virtuais. Abstração. Polimorfismo
Básico de C++: Relacionamentos entre classes: friend. Herança
Básico de C++: Sobrecarga de Operadores, this, Membros estáticos
Traduzindo software com qualidade
Produtos relacionados Topo
Livro: ALGORITMOS O Guia Essencial
Livro: Programando em C - Volume I - Fundamentos - Inclui o padrão ISO C99
Livro: Redes Neurais - Fundamentos e Aplicações com Programas em C
Livro: Estrutura de Dados e Algoritmos Usando C - Fundamentos e Aplicações
Livro: Web Interativa com Ajax e PHP
© Copyright 2001-2010 Codeline Editora, Comércio e Tecnologia Ltda. | Política de privacidade e de uso | Anuncie | Fale conosco

» Site hospedado na Porta 80 Web Hosting «
Nossos números
Dicas: 1.314
Códigos/scripts: 279
Funções de VBScript : 90
Funções JScript : 05
Livros: 1.805
Notícias: 2.488
Artigos: 2.972
Cases: 14
Oportunidades: 4.546
Publicidade

Conheça a loja do Linha de Código.

Microsoft indica Linha de Código.

Assine a Revista Mundo .NET
Portal de Vídeos .NET - os melhores vídeos .NET estão aqui
O que você fará com o Visual Studio 2010?
Revista Codificando .Net

Siga-nos no Twitter

Linha de Código no Orkut
Fórum de discussão do portal Linha de Código
Feeds
Oportunidades
Notícias
Artigos
Artigos personalizado
       (Por assunto)
Artigos personalizado
       (Por autor)
Portal Vídeos .NET
Portal Vídeos Delphi
LC Blog
       (Onde você faz a notícia)
Promoções
Promoção Mobile com entrega via download (válido somente para pagamento via boleto bancário)
Promoção Mobile com entrega via download (válido somente para pagamento via boleto bancário)
De: R$ 189,00
Por: R$ 126,00
Promoção Wordpress + Tabless (válido somente para pagamento via boleto bancário)
De: R$ 149,70
Por: R$ 99,80
Promoção C# Básico (válido somente para pagamento via boleto bancário)
De: R$ 185,90
Por: R$ 136,00
Promoção PHP + MYSQL Intelimax (válido somente para pagamento via boleto bancário)
De: R$ 308,00
Por: R$ 219,00
Promoção Especial Infra
De: R$ 175,95
Por: R$ 136,00
CDs/DVDs
DVD Desenvolvimento de Games - Programando Jogos com o 3D Game Studio
DVD Desenvolvimento de Games - Programando Jogos com o 3D Game Studio
Por: R$ 59,00
DVD Curso de CorelDraw X4
Por: R$ 79,90
DVD Curso de Fireworks CS4
Por: R$ 49,90
DVD Curso de Indesign CS4
Por: R$ 55,00
DVD Curso de Efeitos Digitais
Por: R$ 49,90
Livros
MSProject 2007 - Metodologia e Critérios de Qualidade para o Gerenciamento de Projetos
MSProject 2007 - Metodologia e Critérios de Qualidade para o Gerenciamento de Projetos
De: R$ 129,00
Por: R$ 77,40
Foundation FLASH CS3 para Designers
Ciência Moderna
De: R$ 139,00
Por: R$ 83,40
Recursos Visuais na Web com PHP
Ciência Moderna
De: R$ 49,00
Por: R$ 29,40
Crie um Sistema Web com PHP 5 e AJAX - Controle de Estoque
Erica
De: R$ 99,50
Por: R$ 84,50
Crie Projetos Gráficos com Adobe Photoshop CS4, CorelDRAW X4 e Adobe InDesign CS4 - em Português
Erica
De: R$ 77,50
Por: R$ 65,80
E-Books
Manual Completo de Estudos MCSE 70-270 - Instalando, Configurando e Administrando o Windows XP (506 páginas) - Entrega via download
Manual Completo de Estudos MCSE 70-270 - Instalando, Configurando e Administrando o Windows XP (506 páginas) - Entrega via download
Por: R$ 30,00
Manual de Estudos - Exame 70-291 - Windows Server 2003 (606 páginas) - entrega via download
Por: R$ 30,00
Dominando MS – Visio ® em 20 Passos - Melhores Práticas em Gestão de Projetos (entrega via download)
Por: R$ 30,00
MS-Project® 2007 - Melhores Práticas de Gestão de Projetos - Dominando MS – Project ® em 20 Passos (e-book com entrega via download)
Por: R$ 20,00
Banco de dados com C# e Visual Studio .Net 2005 (entrega via download)
Por: R$ 20,00
Os 10+ | Autores do dia
Israel Aéce
Júlio Cesar Fabris Battisti
Anderson Patricio
Alfred Reinold Baudisch
Luiz Felipe de Freitas
Robert Martim
Ramon Durães
Alessandro de Oliveira Faria
José Carlos Macoratti
Eric C M Oliveira
Os 10+ | Artigos do dia
HTML Básico
HTML Avançado
Criando aplicativos para o Orkut
Tutorial de Tabelas Dinâmicas no Excel – Parte 1
Excel: fórmulas matriciais
ASP.NET 2.0 - Explorando o GridView
Iniciando um projeto de Nota Fiscal Eletrônica - NFe
PL/SQL - Procedures e Funções
Excel: Comparando Listas
PHP: Formulários e upload de múltiplos arquivos e fotos