青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

loop_in_codes

低調做技術__歡迎移步我的獨立博客 codemaro.com 微博 kevinlynx

實現一種解釋性腳本語言(三)

author: Kevin Lynx email: zmhn320#163.com date: 3.7.2009

詞法分析

    詞法分析屬于整個編譯流程中的第一個階段。為什么要把編譯過程分為多個階段,這就
如同軟件分層一樣,個人覺得是出于降低復雜性的考慮。
    再次聲明我不會告訴你任何編譯原理的理論知識,因為坦率地說我也不會:D。所以我努
力將我們需要了解的概念盡可能簡單地告訴你。當然,可能會與教科書不吻合。

什么是詞法分析?

    詞法分析就是把一段話整理成單詞集合。舉個簡單的例子,例如有代碼:age = age + 1;,
經過詞法分析后,將得到:age、=、age、+、1、;幾個符號。為了方便,我稱每個單詞為一
個token。

詞法分析的作用

    詞法分析分析出來的單詞集合,直接作為編譯流程中接下來的語法分析的輸入。那么語
法分析階段面對的將是一個一個的token,而不是單個的字符。
    例如,在處理age = age + 1;這種語句時,當我們獲取到token "="時,我們直接期望接
下來的token應該是個表達式。以單詞為單位地處理,比直接處理單個字符簡單很多。

詞法分析的過程

    詞法分析的輸入是單個字符流,一般我們fopen一個源代碼文件,保存在一個char緩存
里,這就是詞法分析的輸入。而詞法分析的最終輸出結果就是一個一個的token。
    為了處理方便,token并不是單純的單詞。通常我們會將源代碼中的所有單詞分類,例
如變量名其實都屬于一類token。簡單的token可定義為:
    struct Token
    {
        int type;
        char value[256];
    };
    type用于表示token的類型,例如一個變量名token的類型是一個標識符。value可以用
來具體地保存這個變量的名字。

    對于type的處理,通常會事先定義一組枚舉值,例如:
    enum    {    ID, NUM, STRING, IF, ELSE, WHILE, RETURN, FUNCTION }等等用于標示
在一個源代碼中可能出現的所有token。

    雖然說詞法分析的結果是一個token集合,但事實上我們并不是一次做完詞法分析。通常
詞法分析模塊提供一個get_token函數。每次調用該函數時,都返回源代碼中下一個token。
例如,有源代碼:age = age + 1;
    第一次調用get_token將獲得 { ID, "age" },第二次獲得 { ASSIGN, "=" },第三次
獲得{ ID, "age" },等等。

    那么,詞法分析該如何實現?也就是struct Token get_token()函數如何實現?其實很
簡單,你告訴我:給你一個字符串,你如何判斷這個字符串全部是數字?
    int is_num( const char *str )
    {
        while( *str != 0 )
        {
            if( !isdigit( *str++ ) ) return 0;
        }
        return 1;
    }
    所以,基本上,詞法分析的過程也就是這個過程。就拿標識符舉例,典型的標識符一般
以字符開頭,然后接著是數字或字符或_,當遇到非法字符時,這個標識符的掃描即結束。
    詞法分析一般是個while+switch:
    struct Token get_token()
    {
        while( current_char != 0 )
        {
            switch( current_char )
            {
                case CHARACTER:
                    /* 掃描一個標識符 token */
                    break;

                case '=':
                    /* 獲得一個 ASSIGN token */
                    break;

                    ...
            }
        }
    }

    現在,試著去總結一門語言里的每一個token的規則,然后自己去寫寫看。

代碼導讀

    在本節我將提供kl在googlecode的SVN上的代碼,先不要去管代碼包中的其他東西。關于
詞法的代碼可以在kllex.c kllex.h中找到。lex_token是提供給其他模塊的接口,用于獲取
當前掃描的token。掃描結果可以通過lexState結構體獲取。
    再次提下版權問題,代碼文件以及代碼包中我并沒有加入任何版權說明,哪怕是GPL。
但是如同我之前說的一樣,我不介意你傳播、改動此代碼,但是請保留原作者信息。當然,
我并不介意你加上@modified by xxx:)。

    下載kl源代碼:http://klcommon.googlecode.com/files/kllan_0.1.0.zip

posted on 2009-03-07 13:43 Kevin Lynx 閱讀(3857) 評論(2)  編輯 收藏 引用 所屬分類: kl腳本實現編譯原理

評論

# re: 實現一種解釋性腳本語言(三) 2009-03-15 16:28 夢在天涯

while( *str != 0 )
{
if( !isdigit( *str ) ) return 0;
}

為什么不是if(str != 0)
{
if(!isdigit(*str) return 0;
}
return 1;  回復  更多評論   

# re: 實現一種解釋性腳本語言(三) 2009-03-15 16:47 Kevin Lynx

@夢在天涯
這個例子是用于判定一個字符串是否全部是數字,不過例子中寫的有問題,應該是:
int is_number( const char *str )
{
while( *str != 0 )
{
if( !isdigit( *str++ ) ) return 0;
}
return 1;
}

謝謝提醒。
  回復  更多評論   

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            99视频国产精品免费观看| 亚洲肉体裸体xxxx137| 亚洲第一区中文99精品| 欧美xxx成人| 欧美不卡一卡二卡免费版| 夜夜嗨av色一区二区不卡| 99精品欧美一区| 在线精品高清中文字幕| 亚洲精品在线观| 黄色成人免费观看| 在线亚洲电影| 亚洲日本国产| 欧美一级理论片| 一区二区三区日韩欧美| 午夜欧美大尺度福利影院在线看| 亚洲摸下面视频| 亚洲日本欧美日韩高观看| 亚洲永久网站| 亚洲一区欧美激情| 美脚丝袜一区二区三区在线观看| 亚洲女同在线| 欧美日韩国产一级| 亚洲精品一区在线| 亚洲精品在线免费| 欧美在线看片| 久久久久国产精品一区三寸| 国产欧美日韩精品一区| 亚洲图片自拍偷拍| 欧美在线观看视频| 亚洲国产毛片完整版| 国产欧美一区二区精品性| 亚洲无线观看| 久久成人国产| 在线观看视频日韩| 麻豆精品精品国产自在97香蕉| 国产真实久久| 久久大香伊蕉在人线观看热2| 国产精品主播| 国产精品海角社区在线观看| 亚洲精品在线观看视频| 日韩午夜在线视频| 欧美激情a∨在线视频播放| 欧美国产一区在线| 亚洲国产日韩欧美一区二区三区| 久久久久久久一区二区| 久久中文字幕一区| 国产欧美精品日韩| 久久久久国产一区二区| 欧美第一黄网免费网站| 亚洲第一区中文99精品| 国产精品爽爽爽| 欧美日韩免费观看一区三区| 欧美在线关看| 黄色国产精品一区二区三区| 欧美日韩高清在线观看| 午夜视频一区在线观看| 一本色道久久综合狠狠躁的推荐| 久久青草久久| 欧美主播一区二区三区| 久久综合伊人77777麻豆| 亚洲视频在线二区| 欧美国产日本在线| 久久蜜桃香蕉精品一区二区三区| 久久九九99视频| 欧美乱人伦中文字幕在线| 欧美成人亚洲成人| 国产精品日韩高清| 亚洲精选国产| 在线免费观看一区二区三区| 在线日韩成人| 日韩视频免费观看| 亚洲视频香蕉人妖| 亚洲综合不卡| 久久精视频免费在线久久完整在线看| 亚洲欧美精品伊人久久| 久久不见久久见免费视频1| 欧美在线一二三| 久久精品国产第一区二区三区最新章节 | 亚洲视频中文字幕| 亚洲欧美久久久| 久久高清一区| 久久婷婷国产综合精品青草| 久久久久国产精品一区三寸 | 欧美一级欧美一级在线播放| 亚洲第一页中文字幕| 国产视频不卡| 在线欧美影院| 欧美精品性视频| 国产精品国产成人国产三级| 国产麻豆精品久久一二三| 激情文学一区| 久久精品动漫| 在线视频你懂得一区| 另类天堂av| 在线观看国产精品网站| 老**午夜毛片一区二区三区| 欧美一区二区三区免费视| 久久国产精品久久久久久| 欧美1区2区视频| 国产欧美精品一区二区色综合| 精品动漫3d一区二区三区| 亚洲综合不卡| 一区二区三区毛片| 欧美精品乱码久久久久久按摩| 国产一区91精品张津瑜| 欧美在线视屏| 欧美一区二区三区在线| 国产裸体写真av一区二区| 亚洲欧美一级二级三级| 亚洲毛片在线观看| 欧美日韩中文精品| 亚洲性xxxx| 亚洲欧美春色| 国产香蕉久久精品综合网| 久久精品二区亚洲w码| 久久成人精品一区二区三区| 国内揄拍国内精品久久| 久久亚洲一区二区三区四区| 亚洲专区免费| 99re国产精品| 国产九九视频一区二区三区| 欧美在线啊v一区| 欧美一区网站| 亚洲国产另类 国产精品国产免费| 欧美88av| 国产精品亚洲美女av网站| 久久综合久久88| 欧美人与性动交cc0o| 久久精品国亚洲| 欧美激情第一页xxx| 午夜在线播放视频欧美| 久久婷婷人人澡人人喊人人爽| 国产精品高清一区二区三区| 久久成人综合网| 欧美成人免费播放| 欧美在线不卡视频| 欧美日韩精品免费观看视一区二区| 亚洲欧美日韩精品在线| 久久漫画官网| 久久精品一区中文字幕| 欧美剧在线免费观看网站| 久久九九免费| 国产精品久久久久久久久免费桃花| 久久一区二区三区av| 国产精品日韩在线播放| 亚洲欧洲日本国产| 亚洲大片在线| 久久一二三区| 欧美.www| 亚洲国产精品一区二区www| 久久超碰97中文字幕| 久久蜜臀精品av| 精品99视频| 久久蜜桃精品| 欧美国产日韩一区二区在线观看| 一区二区三区四区国产精品| 一区视频在线| 欧美激情国产日韩| 亚洲剧情一区二区| 亚洲一区影音先锋| 国产老肥熟一区二区三区| 午夜日本精品| 欧美高清成人| a91a精品视频在线观看| 国产精品久久久久毛片软件| 亚洲一区二区三区成人在线视频精品| 亚洲一区二区三区影院| 国产在线一区二区三区四区| 久久网站热最新地址| 亚洲精品无人区| 久久精精品视频| 日韩亚洲国产欧美| 国产精品视频精品| 另类av一区二区| 新狼窝色av性久久久久久| 免费欧美日韩| 欧美在线高清视频| 99re这里只有精品6| 国内精品久久久久久久影视蜜臀| 欧美激情91| 欧美大色视频| 亚洲欧美高清| 一二三区精品| 亚洲激情女人| 精品av久久久久电影| 国产日本欧美一区二区三区在线 | 久久av资源网站| 在线亚洲激情| 亚洲视频大全| 亚洲美女诱惑| 亚洲最新视频在线| 黄色精品一区| 国产日韩专区| 国产亚洲精品久久久久动| 国产精品永久免费观看| 国产精品理论片在线观看| 国产精品国产三级国产aⅴ浪潮 | 国产美女精品视频| 国产精品国产a级| 国产模特精品视频久久久久|