词法分析

词法分析

  • 词法分析器:字符流->记号流
  • 词法分析器的手工构造
    • 比较符号的转移图
      转移图.png
    • 标识符的转移图
      • 转移图
        标识符转移图.png
      • 关键字表(哈希表的构造)
  • 正则表达式(ε空集,c为所有ε的子集)
    • 选择 M|N
    • 连接 MN
    • (kleene)闭包 M*
  • 正则表达式语法糖
  • 有限状态自动机
    • FA
      有限状态自动机.png
    • 确定的有限状态自动机详细图 DFA

有限状态自动机图2.png

- 当输入无法到达接受状态时,则称为无法被自动机接受
+ 非确定的有限状态自动机 NFA
-


非确定的有限状态自动机.png

转换

  • RE转换成NFA:(thompson算法)
thompson算法图.jpeg
  • NFA转换成DFA:(子集构造算法)
    • delta(q)->ε闭包

    • ε闭包(深度优先算法)

       set closure = {};  
       void eps_closure(x){  
           closure+= {x};  
           foreach(y:x--ε--y){  
               if(!visited(y)){  
                   eps_closure(y);  
               }  
           }  
       }  
      
    • ε闭包(宽度优先算法)

       set closure={};
       Q=[];
       void eps_closure(x){
           Q=[x];
           while(Q not empty){
               q<-deQueue(Q);
               closure+=q;
               //下面改成了从q出发的所有节点,所以为宽度优先
               foreach(y:q--ε-->y){
                   if(!visited(y)){
                       enQueue(Q,y);
                   }
               }
           }
       }
      
    • 子集构造算法:工作表算法

       q0 <- eps_closure(n0);
       Q <- (q0);
       workList <- q0;
       while(workList!=[]){
           remove q from workList;
           foreach(character c){
               t <- e-closure(delta(q,c));
               d[q,c]<-t;
               if(t is not in Q){
                   add t to Q and worList;
               }
           }
       }
      
    • 实例

NFA.png

- p0={n0}
- p1={n1,n2,n3,n4,n6,n9}(是由p0通过添加a生成的)
- p2={n5,n8,n3,n4,n6,n9}(是由p1通过添加b生成的)
- p3={n7,n8,n9,n3,n4,n6}(是由p1通过c生成)
- p2通过b还是生成自身,p3通过c还是生成自身
-
习题1.png

因为p1,p2,p3都有n9,所以都是终结

  • DFA的最小化(Hopcroft)
    • 第一步,分割开可接收的和不可接收的
    • 第二步,逐步使用可接收的字符进行分割
  • DFA的生成分析算法
    • 转移表

           nextToken(){
               state = 0;//状态值,即p1
               stack = [];//栈
               while(state!=ERROR){
                   c = getchar();
                   if(state is ACCEPT){
                       clear(stack);
                   }
                   push(state);
                   state = table[state][c];
               }
               while(state is not ACCEPT){
                   state = pop();
                   rollback();//回滚到上一个state
               }   
           }
      
    • 跳转表

           nextToken(){
               state = 0;
               stack = [];
               goto q0;
           }
           q0:
               c=getchar();
               if(state is ACCEPT){
                   clear(stack);
               }
               push(state);
               if(c=='a'){
                   goto q1;
               }
               ...
           }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,684评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,143评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,214评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,788评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,796评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,665评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,027评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,679评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,346评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,664评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,766评论 1 331
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,412评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,015评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,974评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,073评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,501评论 2 343

推荐阅读更多精彩内容

  • 写在前面 从源代码到可执行文件要经历几个过程: 词法分析 语法分析 语义分析 中间代码生成 代码优化 词法分析有点...
    wsztrush阅读 1,970评论 0 5
  • 词法分析器的自动生成器的作用: 只需输入合法词的正则表达式,就可以输出一个确定有限状态自动机(DFA),而DFA的...
    拉丁吴阅读 5,650评论 2 6
  • 任务 你将使用图转移算法手工实现一个小型的词法分析器。 分析器的输入:存储在文本文件中的字符序列,字符取自ASCI...
    hzxiao阅读 747评论 0 0
  • 词法分析器 词法分析器又称扫描器。词法分析是指将我们编写的文本代码流解析为一个一个的记号,分析得到的记号(Toke...
    435fa00b72e7阅读 1,600评论 0 3
  • 自制脚本语言(1)--词法分析器 目的:为了实现一个简单的解释器并在其基础上进行修改优化使其成为一个初级的编译器....
    TaXue_WWL阅读 2,159评论 0 1