2010-03-16 86 views

Respuesta

12

L-attributed grammar

gramáticas con atributos son un tipo especial de las gramáticas de atributos. Permiten que los atributos se evalúen en un recorrido de izquierda a derecha del árbol de sintaxis abstracta. Como resultado, la evaluación de atributos en las gramáticas atribuidas a L se puede incorporar convenientemente en el análisis de arriba hacia abajo. Muchos lenguajes de programación tienen L atribuido. Los tipos especiales de compiladores, los compiladores estrechos, se basan en alguna forma de gramática atribuida a L. Estos son comparables con las gramáticas atribuidas a S. Usado para síntesis de código.

gramáticas atribuidas-S

S-attributed grammar

son una clase de gramáticas de atributos que se caracterizan por no tener atributos heredados. Los atributos heredados, que se deben pasar de los nodos principales a los nodos secundarios del árbol de sintaxis abstracta durante el análisis semántico del proceso de análisis, son un problema para el análisis ascendente porque en el análisis ascendente, los nodos principales de la sintaxis abstracta árbol se crean después de la creación de todos sus hijos. La evaluación de atributos en gramáticas atribuidas a S se puede incorporar convenientemente tanto en el análisis sintáctico de arriba hacia abajo como en el análisis de abajo hacia arriba. Yacc se basa en el enfoque de atribución S.

Cualquier gramática atribuida a S es también una gramática atribuida a L.

En L-atribuido la evaluación de atributos de gramáticas se puede realizar en transversal de izquierda a derecha. Como en los atributos de las gramáticas atribuidas a S no se heredan, no impide que haga exactamente eso. Como tal, puedes decir que una gramática atribuida a S se ajusta a esa característica de una L-gramática.

1

Simplemente S-atribuida Gramática es la gramática que ha estrictamente Sintetizado tipo de gramática único medio que tiene el atributo de valor a lo largo del árbol de análisis

donde como la gramática con atributos puede tener ambas cosas sintetizado, así como la gramática heredada con algunos de las reglas como una que tiene la transferencia de herencia de siempre de izquierda a derecha. Creo que te ayudará.

Cuestiones relacionadas