VC语言

本类阅读TOP10

·VC++下使用ADO编写数据库程序
·VC++ 学习笔记(二)
·Windows消息大全
·每个开发人员现在应该下载的十种必备工具
·在2000和xp下,隐藏进程,VC6.0测试通过!!!
·用Visual C++打造IE浏览器(1)
·Netmsg 局域网聊天程序
·教你用VC6做QQ对对碰外挂程序
·VC++学习笔记(四)
·VC++中经常使用的函数!~~

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
一个小语言的词法分析程序原理及其实现(1)

作者:未知 来源:月光软件站 加入时间:2005-2-28 月光软件站

             词法分析是编译程序的第一步,是以后编译步骤:语法分析,语义分析以及代码生成的基础.目前可以利用LEX进行词法分析程序的编写,如果所要翻译的语言比较庞大则应该使用LEX,这就需要学习LEX的使用了,本文不使用该工具,而自己手工编写一个,旨在解除大家对编译系统的神秘感,也希望能给大家一个提示吧.网上有些词法分析程序的原代码,觉得写的挺复杂的。其实词法分析程序的原理都是一样的,所以我想只要搞明白了简单的词法分析程序,再写复杂的就不难了,无非是多加几个关键字,多写几个条件判断语句而已。词法分析是编译程序的基础,也是最简单的。好,现在让我们开始吧。

       先让我们看看这个小语言的文法吧。

G[<程序>]:

        <程序>∷=<程序首部>;<分程序>.

        <程序首部>∷=program<标识符>

        <分程序>∷=<复合语句>    

        <复合语句>∷=begin<语句序列>end 

        <语句序列>∷=<语句>{;<语句>}

         <语句>∷=<赋值语句>|<复合语句>|<条件语句>  

         <赋值语句>∷=<标识符>:=<表达式>

         <条件语句>∷=if <布尔表达式> then <语句> else <语句>

         <表达式>∷=<项>{(+|-)<项>}

         <项>∷=<因式>{(*|/)<因式>}

         <因式>∷=<标识符>|<无正负号常量>|(<表达式>)

         <布尔表达式>∷=<表达式><关系运算符><表达式>

         <关系运算符>∷= =|<|<=|>|>=|<>

         <标识符>∷=<字母>{<字母>|<数字>}

         <无正负号常量>∷=<数字>{<数字>}[.<数字>{<数字>}]

         <字母>∷=a|b|c|d|e|f|g|……|u|v|w|x|y|z

         <数字>∷=0|1|2|3|4|5|6|7|8|9

    根据此文法,构造一词法分析程序。输入以“#”为结束符

按照这个文法,找出该语言的关键字,如program,begin,end ,if,then,else,以及其他一些特殊符号,然后再构造一个分析表,如下表:

单词符号

类别编号

单词符号

类别编号

标识符

1

)

14

常数

2

>

15

if

3

>=

16

then

4

<

17

else

5

<=

18

program

6

<>

19

begin

7

:=

20

end

8

;

21

+

9

.

22

-

10

23

*

11

 

 

/

12

 

 

(

13

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 




相关文章

相关软件




月光软件程序下载编程文档电脑教程网站设计网址导航网络文学游戏天地幽默笑话生活休闲写作范文安妮宝贝
电脑技术编程开发网络专区谈天说地情感世界游戏元素分类游戏热门游戏体育运动手机专区业余爱好影视沙龙
音乐天地数码广场教育园地科学大观古今纵横谈股论金人文艺术医学保健动漫图酷二手专区地方风情各行各业

月光软件站·版权所有