Lex Es Un Programa para Generar Analizadores Léxicos

Descargar como docx, pdf o txt
Descargar como docx, pdf o txt
Está en la página 1de 12

Lex es un programa para generar analizadores léxicos.

Lex se utiliza comúnmente con el


programa yacc que se utiliza para generar análisis sintáctico. Lex, escrito originalmente por Eric
Schmidt y Mike Lesk, es el analizador léxico estándar en los sistemas Unix, y se incluye en el
estándar de POSIX. Lex toma como entrada una especificación de analizador léxico y devuelve
como salida el código fuente implementando el analizador léxico en C.

La estructura de un archivo de lex es intencionadamente similar a la de un archivo del


yacc; los archivos se dividen en tres secciones, separadas por líneas que contienen
solamente dos símbolos "%", como sigue:

 Sección de declaraciones
%%”·$·%$%&
 Sección de reglas
%%!””·$%$
 Sección de código en C

 La sección de declaraciones es el lugar para definir macros y para importar los


archivos de cabecera escritos en C. También es posible escribir cualquier código
de C aquí, que será copiado en el archivo fuente generado. Este código en C
debe ir entre los símbolos %{ %}.

      También se pueden incluir "atajos" para definir patrones de la Sección de Reglas,


por ejemplo en vez del patrón [0-9]* (cero o más dígitos que reconocerían cualquier
número natural), se puede definir en esta sección el "atajo":  números [0-9]*, así, en la
sección de código pondríamos el patrón {números} {acción_en_C;}. Con esto se
clarifica la escritura del código en lex.

 La sección de reglas es la sección más importante; asocia patrones a sentencias


de C. Los patrones son simplemente expresiones regulares. Cuando el lexer
encuentra un texto en la entrada que es asociable a un patrón dado, ejecuta el
código asociado de C. Ésta es la base de del funcionamiento de lex.
 La sección de código C contiene sentencias en C y funciones que serán copiadas
en el archivo fuente generado. Estas sentencias contienen generalmente el
código llamado por las reglas en la sección de las reglas. En programas grandes
es más conveniente poner este código en un archivo separado y enlazarlo en
tiempo de compilación.
FLEX

Es una herramienta para la generación de programas que realizan concordancia de patrones en


texto. El manual incluye a la vez secciones de tutorial y de referencia: 

Descripción una breve introducción a la herramienta Algunos Ejemplos Simples. Formato del
Fichero de Entrada Patrones las expresiones regulares extendidas que utiliza flex Cómo se
Empareja la Entrada, las reglas para determinar lo que ha concordado Acciones cómo
especificar qué hacer cuando concuerde un patrón El Escáner Generado detalles respecto al
escáner que produce flex; cómo controlar la fuente de entrada Condiciones de Arranque la
introdución de contexto en sus escáneres, y conseguir "mini-escáneres" Múltiples Buffers de
Entrada cómo manipular varias fuentes de entrada; cómo analizar cadenas en lugar deficheros.
Reglas de Fin-de-Fichero reglas especiales para reconocer el final dela entrada Macros
Misceláneas un sumario de macros disponibles para las acciones Valores Disponibles para el
Usuario un sumario de valores disponibles para las acciones Interfaz con Yacc conectando
escáneres de flex junto con analizadores de yacc Opciones de línea de comando de flex, y la
directiva "%option" Consideraciones de Rendimiento cómo hacer que sus analizadores vayan
tan rápido como sea posible Generando Escáneres en C++ la facilidad (experimental) para
generar analizadores léxicos como clases de C++ Incompatibilidades con Lex y POSIX cómo
flex difiere del lex de AT&T y dellex estándar de POSIX Diagnósticos esos mensajes de error
producidos por flex(o por los escáneres que este genera) cuyo significado podría no ser evidente
Ficheros. los ficheros usados por flex Deficiencias / Errores problemas de flex conocidos Ver
También otra documentación, herramientas relacionadas al Autor incluye información de
contacto.

 
GENERADORES DE CODIGO LEX Y FLEX

Las expresiones regulares (propiamente dichas, en un sentido estricto), tal y como se


estudian en la teoría de lenguajes para especificar los lenguajes regulares, están
constituidas por símbolos de un alfabeto Σ, relacionados mediante los operadores
binarios alternativa ( | ) y concatenación ( • ) y el operador unario estrella ( * ); en la
escritura de una expresión regular también se pueden emplear paréntesis para
precisar el orden de aplicación de los operadores. El asterisco de la operación estrella
suele colocarse como exponente de la parte de la expresión regular afectada.
La precedencia de los operadores es la definida por la siguiente jerarquía, relacionada
de mayor a menor precedencia:
1 operaciones entre paréntesis
2 operador estrella
3 operador concatenación
4 operador alternativa
Así, por ejemplo, son expresiones regulares definidas sobre el alfabeto Σ = { a, b }
b•a•a|b•b
a*•(b|b•a)
Entre los símbolos que aparecen en una expresión regular cabe distinguir los
caracteres y los metacaracteres; los caracteres son los símbolos que pertenecen al
alfabeto sobre el que está definida la expresión regular; los metacaracteres son los
símbolos que no pertenecen a ese alfabeto: los operadores y los paréntesis.
En la escritura de las expresiones regulares el punto representativo de la
concatenación entre símbolos del alfabeto suele suprimirse; de acuerdo con esta
notación simplificada, las anteriores expresiones suelen escribirse así:
baa|bb
a*(b|ba) Dado que el espacio en blanco no es un símbolo perteneciente al alfabeto Σ
sobre el que están definidas las expresiones regulares anteriores, también podrían
escribirse (sin ocasionar confusión y con la pretensión de favorecer la legibilidad) de
esta manera:
baa | bb
a* ( b | ba )
En una especificación Lex se incluyen expresiones regulares, pero escritas con una
notación que es una ampliación de la notación empleada en la definición (en sentido
estricto) anterior. Esta ampliación tiene como principales objetivos:
hacer más cómoda y escueta la escritura de las expresiones regulares,
distinguir de manera precisa los caracteres del alfabeto y los metacaracteres
empleados en la escritura de las expresiones regulares.
Sea el alfabeto Σ = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9}, la expresión regular que denota las
palabras de longitud uno es:
0|1|2|3|4|5|6|7|8|9
Con la notación ampliada de las expresiones regulares Lex (empleando unos nuevos
metacaracteres: el guión y los corchetes de abrir y de cerrar), esa misma expresión
puede escribirse así:
[0–9]
Las expresiones regulares de una especificación Lex han de procesarse mediante un
programa y, por ello, han de estar grabadas en un fichero de tipo texto. En estas
condiciones no resulta adecuado el convenio según el cual la operación estrella se
escribe en forma de exponente; por ejemplo, la expresión regular
ab*
quedaría grabada en el fichero mediante la secuencia de tres caracteres consecutivos
ab*. Si Σ = {+, -, , /} es el alfabeto sobre el que definen las expresiones regulares, ¿qué
lenguaje denota la expresión regular + grabada como una secuencia de dos
caracteres? La respuesta depende de si el asterisco se considera como carácter del
alfabeto o como operador (metacarácter).
Las expresiones regulares empleadas en las especificaciones Lex no tienen
conceptualmente ninguna diferencia con las expresiones regulares (en sentido
estricto) que definen los lenguajes formales regulares; lo único que aportan son
modificaciones en la notación empleada en la escritura de las expresiones en forma de
secuencias de caracteres consecutivos susceptibles de grabarse en un fichero de tipo
texto. Esta notación ampliada alcanza cierta dificultad por las siguientes causas:
para facilitar y acortar la escritura de las expresiones se introducen bastantes
metacaracteres
es habitual que cualquier carácter del alfabeto ASCII forme parte del alfabeto sobre
el que se
se precisa la definición de convenios para distinguir entre los caracteres y los
metacaracteres.
En lo que sigue se emplea la notación  para indicar que lo que se pone a
continuación de esos símbolos es la descripción del conjunto de palabras denotadas
por la expresión regular que les precede. Nuevos operadores de las expresiones
regulares Lex
Además de las operaciones empleadas en las expresiones regulares en sentido
estricto (alternativa, concatenación y estrella, con la jerarquía entre ellas que antes se
ha citado), en las expresiones regulares Lex se incorporan las operaciones unarias que
se describen a continuación. Los ejemplos que acompañan a las descripciones se
refieren al alfabeto Σ = {x, y, z}.
Operación opcionalidad ?
Representa la presencia una única vez o la ausencia de las palabras denotadas por la
expresión regular afectada; tiene la misma prioridad que la operación estrella. En
general, si α es una expresión regular, se verifica la equivalencia entre α? y α|ε. Por
ejemplo,
x|y?  {x, y, ε}
(x|y)?  {x, y, ε}
xz?|zzy  {x, xz, zzy}
(xz)?|zzy  {ε, xz, zzy}
Operación repetición una o más veces +
Representa la presencia una o más veces consecutivas de las palabras denotadas por
la expresión regular afectada; tiene la misma prioridad que la operación estrella. En
general, si α es una expresión regular, se verifica la equivalencia entre α+ y αα*. Por
ejemplo,
Operación repetición limitada { }
Representa la presencia un número dado y limitado de veces consecutivas de las
palabras denotadas por la expresión regular afectada; tiene más prioridad que la
alternativa pero menos que la concatenación.
La cantidad de presencias se indica mediante los números puestos entre las llaves; hay
tres maneras de hacerlo:
{n} presencia de n veces
{n,m} presencia de i veces, n  i  m
{n,} presencia de i veces, n  i
En general, si α es una expresión regular, se verifica la equivalencia (considerada para
el valor particular 4) entre α{4} y αααα. Por ejemplo,
xy2}
(xy){2,3}  {xyxy, xyxyxy}
x(y{2,4})z  {xyyz, xyyyz, xyyyyz}
En la expresión (xy){2,3} los paréntesis son superfluos, mejoran la legibilidad de la
expresión; la expresión x{1,} denota el mismo conjunto que la expresión x+; la
expresión xy{1,} no denota el mismo conjunto que la expresión xy+, sino el mismo que
(xy)+.
Se observa que en los ejemplos anteriores nunca se ha utilizado el espacio en blanco
como separador para una pretendida mejora en el entendimiento de lo denotado por
la expresión regular; con ello se quiere insistir en que las expresiones regulares Lex
están formadas por una secuencia de caracteres y metacaracteres colocados
consecutivamente (el espacio en blanco no pertenece al alfabeto de las expresiones de
los ejemplos anteriores). Una vez descritos los nuevos operadores añadidos a las
expresiones regulares Lex, se hace ahora una recapitulación de los operadores
disponibles y de la jerarquía de su aplicación; relacionada de mayor a menor, es como
sigue:
Los operadores que tienen la misma prioridad se aplican de izquierda a derecha,
según se encuentran en la expresión regular; los operadores unarios (*, +, ?, {}) se
aplican a la parte de la expresión regular que está situada a su izquierda (para
determinar la parte afectada por el operador unario, se tiene en cuenta la jerarquía de
las opereaciones). Así pues los metacaractreres hasta ahora considerados son
()*+?{}|
(en las expresiones regulares Lex nunca se pone el punto representativo de la
operación concatenación). Los símbolos que aparecen entre las llaves del operador de
repetición limitada forman parte del propio operador (hacen la función de
metacaracteres). Una vez vistos los anteriores ejemplos iniciales de expresiones
regulares sobre el alfabeto Σ = {x, y, z}, los ejemplos que se ponen en el resto de este
capítulo son de expresiones regulares sobre el alfabeto formado por todos los
caracteres ASCII que se pueden imprimir. Carácter seleccionado entre los caracteres
de un conjunto Para indicar, dentro de una expresión regular Lex, la presencia de un
carácter del alfabeto elegido entre un conjunto de caracteres, se introduce una
notación más cómoda que emplea los corchetes como metacaracteres; en el sitio de la
expresión regular donde deba estar el carácter se pone entre corchetes el conjunto de
los caracteres posibles; todos los caracteres del conjunto se ponen consecutivos, sin
separación alguna entre ellos. Por ejemplo, la expresión regular:
representa las palabras formadas por la letra x, seguida de una cifra decimal, seguida
de la letra y; con la notación de los corchetes se puede escribir así:
Aunque se ponen todas las cifras decimales en el conjunto, la expresión regular define
la presencia de únicamente una de ellas en cada palabra denotada. La descripción
dentro de los corchetes de los caracteres que pertenecen al conjunto puede hacerse
varias maneras; son las siguientes: a) Descripción por enumeración. Dentro de los
corchetes se ponen consecutivamente, sin separación alguna entre ellos, todos los
caracteres del alfabeto que constituyen el conjunto. Por ejemplo, el siguiente conjunto
representa una de las vocales minúsculas:
b) Descripción por enumeración complementaria. Dentro de los corchetes se ponen
consecutivamente, sin separación alguna entre ellos, todos los caracteres del alfabeto
que no pertenecen al conjunto que se define; para indicar esa exclusión se coloca el
carácter ^ de inmediato a continuación del corchete de abrir. Por ejemplo, el siguiente
conjunto representa uno cualquiera de los caracteres del alfabeto sobre el que están
definidas las expresiones regulares, excepto las vocales mayúsculas
c) Descripción por rango. Cuando todos los caracteres que constituyen el conjunto
tienen valores ordinales consecutivos (están seguidos en la ordenación de caracteres
del alfabeto ASCII), en el conjunto se puede poner sólo el primero y el último
separados por un guión; entre el guión y los dos caracteres extremos no hay
separación alguna. Por ejemplo, el siguiente conjunto representa una de las cifras
decimales:
d) Descripción combinada. También pueden combinarse dentro de un mismo
conjunto las tres maneras precedentes; ha de tenerse en cuenta que el carácter
indicativo de enumeración complementaria sólo puede aparecer una vez detrás del
corchete de abrir. Por ejemplo, [135A-Z97]  una de las letras mayúsculas o una de
las cifras impares [a-zA-Z]  una letra cualquiera, minúscula o mayúscula [^97531a-z]
 cualquier carácter del alfabeto, excepto letra minúscula o cifra impar En todas las
maneras de descripción es indiferente el orden de colocación de los caracteres y
también puede haber repeticiones (que resultan inútiles). Por ejemplo, el conjunto
formado por los signos de puntuación coma, punto y coma, punto y dos puntos puede
representarse así:
[,;.:] [:;,.] [..,;::.]
y el conjunto cuyos caracteres son las cifras y las letras (minúsculas y mayúsculas), así:
[0–9a-zA-Z] [a-z0–9A-Z] [00–90a-z0A-Z0]
Los conjuntos de caracteres y la jerarquía de las operaciones La inclusión de un
conjunto de caracteres entre corchetes en una expresión regular representa la
presencia de un único carácter en las palabras denotadas; por ello, en una expresión
regular pueden estar presentes tantas definiciones de conjuntos de caracteres como
se quiera. A efectos de la jerarquía de las operaciones, el conjunto hace las veces de un
único carácter del alfabeto incorporado a la expresión regular. En consecuencia los
conjuntos de caracteres se pueden combinar con cualquiera de los operadores y no es
preciso enunciar nuevas reglas sobre el orden de realización de las operaciones. A
continuación se muestran algunos ejemplos (el símbolo  se usa para representar el
espacio en blanco como carácter dentro de una expresión regular y el símbolo  para
indicar la presencia de un espacio en blanco dentro de una palabra denotada por la
expresión regular). (N|n)oche  palabra noche con la inicial en minúscula o en
mayúscula [Nn]oche  mismas dos palabras que la expresión anterior (n|N)(o|O)|(s|
S)(i|I)  una de palabras no o si con letras minúsculas o mayúsculas [nN][oO]|[sS][iI]
 mismas ocho palabras que la expresión anterior 3[a-z]|[A-Z]*9  palabras cuya
forma es un 3 seguido de una letra minúscula o bien cero o más letras mayúsculas
seguidas de un 9 (x|y|z)+  palabras de longitud mayor o igual que 1, formadas con
las letras x, y, z [xyz]+  mismas palabras que la expresión anterior x[]?y  {xy , xy}
z[:=]z  {zz, z:z, z=z} x[0–9]{2}  palabras de cuatro caracteres; el primero y el
tercero son x; el segundo y el cuarto son una cifra decimal; una palabra denotada es,
por ejemplo, x5×3; sin embargo, la palabra x53 no está denotada z(yx[12]{0,2})  {z,
zyx1, zyx2, zyx1yx1, zyx1yx2, zyx2yx1, zyx2yx2} [0–9]+[a-z]+  las palabras formadas
por una o más cifras decimales, seguidas de una o más letras minúculas [A-Z][,;]{1,} 
las palabras con un número par de caracteres; los que ocupan las posicion es impares
son letras mayúsculas y los de las posiciones pares son una coma o un punto y coma;
por ejemplo: P,Q,P;M, Si en una misma expresión regular Lex hay varias definiciones
de conjuntos de caracteres, para asociar los correspondientes corchetes de abrir y de
cerrar se considera un recorrido de izquierda a derecha de los caracteres (y
operadores) de la expresión regular; en este recorrido, una vez hallado un corchete de
abrir, se asocia con el primero de los corchetes de cerrar que se encuentra (no tiene
sentido alguno pensar en “corchetes anidados”). Así, por ejemplo, la expresión x[[]x
representa la palabra x[x ya que el segundo de los corchetes de abrir es el único
carácter del conjunto que se define delimitado por los otros dos corchetes. Esa
expresión regular es, en efecto, correcta aunque hay más corchetes de abrir que de
cerrar: de los dos corchetes de abrir uno es carácter y el otro es metacarácter. Los
conjuntos de caracteres y los metacaracteres La forma en que se incorpora un
conjunto de caracteres como parte de una expresión regular Lex hace que los
corchetes de abrir y de cerrar deban considerarse como metacaracteres en algunas de
sus presencias. Considérense las siguientes dos situaciones o estados que se presentan
cuando se re¬corre una expresión regular de izquierda a derecha: 1) Estado sin un
conjunto abierto, cuando no se ha encontrado ningún corchete de abrir o si se ha
encontrado alguno también se ha encontrado su correspondiente corchete de cerrar.
2) Estado con un conjunto abierto, cuando se ha encontrado un corchete de abrir y
todavía no se ha encontrado su correspondiente corchete de cerrar. Si no hay un
conjunto abierto, el corchete de abrir es un metacarácter y el corchete de cerrar es un
carácter; si hay un conjunto abierto el corchete de abrir es un carácter y el corchete de
cerrar es un metacarácter. Entre los caracteres que se escriben delimitados por los
corchetes hay dos que tienen un significado especial: ^ y -; por ello, han de
considerarse como metacaracteres; así ocurre, pero teniendo en cuenta los siguientes
condicionantes:
-Los símbolos ^ y - no son metacaracteres cuando aparecen en la expresión regular
fuera del conjunto (fuera de los caracteres que se escriben entre corchetes).
-El símbolo ^ sólo se considera metacarácter si sigue inmediatamente al corchete de
abrir; si se encuentra en otra posición dentro de los corchetes no tiene significado
especial y es un carácter más del conjunto que se describe.
` - El símbolo - sólo se considera metacarácter si, situado entre loscorchetes, está
precedido y seguido inmediatamente por algún carácter del conjunto; si ocupa la
primera posición (no está precedido por ninguno) o la última posición (no está seguido
por ninguno) en la secuencia delimitada por los corchetes, no tiene significado especial
y es un carácter más del conjunto que se describe.`
Supresión con la barra hacia atrás La presencia del símbolo en una expresión regular
hace que el símbolo que está situado a su derecha se considere como carácter (con su
propio significado). Si el símbolo que está a su derecha es un carácter (propiamente
dicho), la presencia de la barra no tiene efecto; si el símbolo que está a su derecha es
un metacarácter, pierde esa calidad. Este efecto del símbolo se cumple para los
metacaracteres externos y también para los internos. Debe notarse que el símbolo
afecta exclusivamente al carácter que está a su derecha.
` Así pues, el símbolo es un nuevo metacarácter, tanto externo como interno, ya que
en cualquiera de los dos contextos en los que se encuentre no se le considera con su
significado propiamente dicho. A continuación se exponen unos ejemplos.`
` Hay dos situaciones en las que la presencia de las comillas noproduce la supresión de
la condición de metacarácter:`
1El símbolo \ mantiene su significado de metacarácter aunque esté entre comillas.
` 2 Cuando el símbolo “ está dentro de la definición de un conjunto de caracteres, es
decir, está en una secuencia de caracteres delimitada por corchetes, seconsidera como
carácter propiamente dicho (perdido su significado como metacarácter).`
│ │⌂│ │⌂│ ∙ ∙ ∙ ∙ ∙ │⌂│ │⌂│
└───────────┴─┴──────────────┴─┴──── ─ ─ ─ ─
────────┴─┴────────────┴─┘
Si se mira el contenido del fichero como una secuencia ininterrumpida de caracteres
de un cierto alfabeto, el carácter especial de final de línea ha de considerarse como un
carácter más de la secuencia; es decir, se trata de un carácter del alfabeto al que
pertenecen los caracteres grabados en el fichero.
` En las expresiones regulares Lex el carácter indicativo del final de línea se representa
mediante el par de caracteres consecutivos n. Por ejemplo,`
│⌂│abb abbbb ab│⌂│
────────┴─┴────────────────────────────────────────┴─┴──────
Las tres palabras abb, abbbb y ab están denotadas por la expresión regular ab+; pero
sólo la palabra abb cumple además la condición de estar situada al principio de la línea
y sólo la palabra ab cumple además la condición de estar situada al final de la línea.
` Para indicar que una palabra sólo se considera efectivamente denotada por una
expresión regular cuando está denotada por ella y además está situada al principio de
la línea se emplea el símbolo ^; si se quiere exigir que esté al final de la línea, se
emplea el símbolo $ . El símbolo ^ se coloca como primer carácter de la expresión y el
símbolo $ como último carácter de la expresión. La presencia del símbolo $ obliga a
considerar los últimos caracteres de una línea, pero excluyendo siempre el carácter de
final de línea. En una misma expresión regular pueden incluirse el metacarácter de
principio y también el metacarácter de final. Por ejemplo,`
^ab+  las palabras denotadas por la expresión ab+ que estén situadas al principio de
una línea; en las palabras de la figura anterior, abb está denotada por ^ab+, pero no lo
están las palabras abbbb y ab ab+$  las palabras denotadas por la expresión ab+ que
estén situadas al final de una línea; en las palabras de la figura anterior, ab está
denotada por ab+$, pero no lo están las palabras abb y abbbb ^[0–9]{4}  los
números de cuatro cifras situados al principio de una línea [0–9]$  los números de
una cifra situados al final de una línea ^-+$  secuencia de uno o más símbolos - que
ocupan una línea completa
Los símbolos ^ y $ son, pues, metacaracteres cuando aparecen, respectivamente, al
principio y al final de una expresión regular; son metacaracteres externos. Nótese que
el símbolo ^ ya se ha descrito antes también como metacarácter interno; en efecto,
según el sitio donde aparezca en la expresión regular, puede ser metacarácter externo,
metacarácter interno o carácter (con su significado propiamente dicho). Contexto de
una palabra Cuando se dice que una expresión regular Lex denota cierta palabra, se
está considerando que esa palabra está constituida por una secuencia de caracteres
consecutivos grabados en un fichero de tipo texto (con estructura de líneas). Puede
hablarse, por lo tanto, de los caracteres que están grabados antes y después de la
palabra, es decir, del contexto en el que se encuentra la palabra. Contexto por la
derecha Se llama contexto por la derecha de una palabra (grabada en el fichero) a la
secuencia de caracteres grabados en el fichero a continuación de la palabra. La
siguiente figura ilustra esta definición.
│⌂│ δ │⌂│
────────┴─┴────────────────┴────────┴────────────────┴─┴──────
La palabra δ, que está denotada por una cierta expresión regular Lex, puede
considerarse como una subpalabra de la secuencia de caracteres grabados en el
fichero de tipo texto; el contexto por la derecha de δ está formado por los caracteres
situados a su derecha. Por ejemplo,
│⌂│ │a│b│a│b│*│:│1│2│3│4│⌂│;│B│
────────┴─┴──────────────────────┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴─┴───
──
la palabra abab*, grabada en el fichero, está denotada por la expresión regular (ab)+*;
en el contexto por la derecha de esta palabra están grabadas las siguientes secuencias
de caracteres:
y así sucesivamente, relacionadas por longitudes crecientes. (Nótese que el carácter
de final de línea se considera como cualquier otro carácter; en la figura y en las
palabras está representado mediante el símbolo ⌂).
Si α y ß son dos expresiones regulares Lex, entonces α/ß también es una expresión
regular Lex que denota las palabras δ que verifican las dos condiciones siguientes:
δ está denotada por α - en el contexto por la derecha de δ hay una palabra
denotada por ß Así, en el ejemplo anterior, la palabra abab* está denotada por las
expresiones regulares (entre otras infinitas posibles) siguientes: (ab)+\*/: (ab*)+\*/:
[0–9]+ (ab)+\*/[:;]
pero no lo está por:
(ab)+\*/;]
Es importante apreciar que los caracteres que constituyen el contexto por la derecha
no forman parte de la palabra denotada.
`En una expresión regular no puede aparecer más de una vez el símbolo / con el
significado de separación entre la parte de la expresión que denota la palabra
propiamente dicha y la parte que denota una palabra del contexto por la derecha. Se
tiene, pues, que el símbolo / es un metacarácter externo; para incluir en una expresión
regular el símbolo / considerado como carácter se puede emplear alguna de las
notaciones ya descritas.`
El metacarácter $ cuyo significado se ha descrito anteriormente es un caso particular
de contexto por la derecha; $ indica que la expresión regular a la que sigue tiene como
contexto por la derecha el carácter de final de línea; esto es, si α es una expresión
regular se verifica que las dos expresiones regulares
α$ α/\n
son equivalentes. Por este motivo no está permitido que en una misma expresión
regular Lex se en¬cuentren los dos metacaracteres $ y /.
Las siguientes ejemplos pretenden mostrar la utilidad de la fijación de un contexto por
la derecha.
[a-zA-Z]+/! 
las palabras formadas por una o más letras (minúsculas o mayúsculas), siempre y
cuando estén seguidas por signo de admiración (en el fichero donde está grabada la
palabra); el signo de admiración no forma parte de la palabra denotada
[A-Z][a-z]*/[ \t\n,;.] 
`las palabras que empiezan por una letra mayúscula que va seguida de cero o más
letras minúsculas, siempre y cuando a continuación de la última letra de la palabra se
encuentre un espacio en blanco, un carácter tabulador, un carácter de final de línea,
una coma, un punto y coma o un punto (en el fichero donde esté grabada la palabra);
el carácter del contexto por la derecha no pertenece a palabra denotada`
Contexto por la izquierda
Se puede imponer que una palabra sólo sea denotada efectivamente por una
expresión regular Lex cuando los símbolos grabados a la izquierda de la palabra
cumplan una determinada condición; para ello se tienen las denominadas condiciones
de contexto (start conditions); cada condición de contexto tiene asociado un nombre;
si se quiere imponer una condición de contexto a una expresión regular se escribe el
nombre de la condición, delimitado por los símbolos < y >, seguido inmediatamente
por la expresión regular afectada. Por ejemplo, la expresión regular Lex
`indica que en el contexto por la izquierda de la palabra denotada debe cumplirse la
condición de contexto cuyo nombre es Condicion.`
` Ni la definición ni el uso de las condiciones de contexto se exponen aquí; sólo se deja
constancia de su existencia.`
Obsérvese que los símbolos < y > son metacaracteres externos; el símbolo < se
considera como metacarácter cuando aparece como primer carácter de una expresión
regular; el símbolo > se considera como metacarácter cuando puede asociarse con el
metacarácter.
MANEJO TEMPORAL DE MEMORIA BUFFER

Es una técnica para proporcionar la simulación  de  un  espacio de  memoria mucho
mayor que la memoria física de una máquina. Esta "ilusión" permite que los programas
se hagan sin tener en cuenta el tamaño exacto de la memoria física.

Está soportada por el mecanismo de traducción de memoria, junto con una gran
cantidad de  almacenamiento  rápido  en  disco  duro.  Así en  cualquier  momento  el 
espacio  de direcciones virtual hace un seguimiento de tal forma que una pequeña parte
de él, está en memoria real y el resto almacenado en el disco, y puede ser referenciado
fácilmente.

Ha llegado a ser un componente esencial de la mayoría de los S.O actuales. Y como en


un instante dado, en la memoria sólo se tienen unos pocos fragmentos de un proceso
dado, se pueden mantener más procesos en la memoria. Es más, se ahorra tiempo,
porque los fragmentos que no se usan no se cargan ni se descargan de la memoria. Sin
embargo, el S.O debe saber cómo gestionar este esquema. También simplifica la carga
del programa para su ejecución llamado reubicación, este procedimiento permite que el
mismo programa se ejecute en cualquier posición de la memoria física. 

En un estado estable, prácticamente toda la memoria principal estará ocupada con


fragmentos de procesos, por lo que el procesador y el S.O tendrán acceso directo a la
mayor cantidad de procesos posibles, y cuando el S.O traiga a la memoria un fragmento,
deberá expulsar otro. Si expulsa un fragmento justo antes de ser usado, tendrá que traer
de nuevo el fragmento de manera casi inmediata. Demasiados intercambios de
fragmentos conducen a lo que se conoce como hiperpaginación: donde el procesador
consume más tiempo intercambiando fragmentos que ejecutando instrucciones de
usuario. Para evitarlo el S.O intenta adivinar, en función de la historia reciente, qué
fragmentos se usarán con menor probabilidad en un futuro próximo.

Los argumentos anteriores se basan en el principio de cercanía o principio de localidad


que afirma que las referencias a los datos y el programa dentro de un proceso tienden a
agruparse. Por lo tanto, es válida la suposición de que, durante cortos períodos de
tiempo, se necesitarán sólo unos pocos fragmentos de un proceso.

Una manera de confirmar el principio de cercanía es considerar el rendimiento de un


proceso en un entorno de memoria virtual.

El principio de cercanía sugiere que los esquemas de memoria virtual pueden funcionar.
Para que la memoria virtual sea práctica y efectiva, se necesitan dos ingredientes.
Primero, tiene que existir un soporte de hardware y, en segundo lugar, el S.O debe incluir
un software para gestionar el movimiento de páginas o segmentos entre memoria
secundaria y memoria principal.
BUFFER DE TRADUCCIÓN ADELANTADA

Cada referencia a la memoria virtual puede generar dos accesos a la


memoria: uno para obtener la entrada  de la tabla de páginas
correspondientes y otro para obtener el dato deseado.

También podría gustarte