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

loop_in_codes

低調(diào)做技術(shù)__歡迎移步我的獨(dú)立博客 codemaro.com 微博 kevinlynx

實(shí)現(xiàn)一種解釋性腳本語(yǔ)言(三)

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

詞法分析

    詞法分析屬于整個(gè)編譯流程中的第一個(gè)階段。為什么要把編譯過(guò)程分為多個(gè)階段,這就
如同軟件分層一樣,個(gè)人覺(jué)得是出于降低復(fù)雜性的考慮。
    再次聲明我不會(huì)告訴你任何編譯原理的理論知識(shí),因?yàn)樘孤实卣f(shuō)我也不會(huì):D。所以我努
力將我們需要了解的概念盡可能簡(jiǎn)單地告訴你。當(dāng)然,可能會(huì)與教科書(shū)不吻合。

什么是詞法分析?

    詞法分析就是把一段話整理成單詞集合。舉個(gè)簡(jiǎn)單的例子,例如有代碼:age = age + 1;,
經(jīng)過(guò)詞法分析后,將得到:age、=、age、+、1、;幾個(gè)符號(hào)。為了方便,我稱每個(gè)單詞為一
個(gè)token。

詞法分析的作用

    詞法分析分析出來(lái)的單詞集合,直接作為編譯流程中接下來(lái)的語(yǔ)法分析的輸入。那么語(yǔ)
法分析階段面對(duì)的將是一個(gè)一個(gè)的token,而不是單個(gè)的字符。
    例如,在處理age = age + 1;這種語(yǔ)句時(shí),當(dāng)我們獲取到token "="時(shí),我們直接期望接
下來(lái)的token應(yīng)該是個(gè)表達(dá)式。以單詞為單位地處理,比直接處理單個(gè)字符簡(jiǎn)單很多。

詞法分析的過(guò)程

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

    對(duì)于type的處理,通常會(huì)事先定義一組枚舉值,例如:
    enum    {    ID, NUM, STRING, IF, ELSE, WHILE, RETURN, FUNCTION }等等用于標(biāo)示
在一個(gè)源代碼中可能出現(xiàn)的所有token。

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

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

                case '=':
                    /* 獲得一個(gè) ASSIGN token */
                    break;

                    ...
            }
        }
    }

    現(xiàn)在,試著去總結(jié)一門(mén)語(yǔ)言里的每一個(gè)token的規(guī)則,然后自己去寫(xiě)寫(xiě)看。

代碼導(dǎo)讀

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

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

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

評(píng)論

# re: 實(shí)現(xiàn)一種解釋性腳本語(yǔ)言(三) 2009-03-15 16:28 夢(mèng)在天涯

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

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

# re: 實(shí)現(xiàn)一種解釋性腳本語(yǔ)言(三) 2009-03-15 16:47 Kevin Lynx

@夢(mèng)在天涯
這個(gè)例子是用于判定一個(gè)字符串是否全部是數(shù)字,不過(guò)例子中寫(xiě)的有問(wèn)題,應(yīng)該是:
int is_number( const char *str )
{
while( *str != 0 )
{
if( !isdigit( *str++ ) ) return 0;
}
return 1;
}

謝謝提醒。
  回復(fù)  更多評(píng)論   

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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精品热视频| 91久久在线| 狂野欧美一区| 亚洲精品乱码久久久久久按摩观| 好看的av在线不卡观看| 国产精品欧美日韩一区| 欧美日韩一区国产| 欧美日一区二区三区在线观看国产免| 麻豆成人综合网| 美女福利精品视频| 免费观看久久久4p| 欧美激情精品久久久久久大尺度| 久久久久久噜噜噜久久久精品 | 亚洲精品一区二区三区av| 久久阴道视频| 亚洲视频第一页| 亚洲神马久久| 午夜精品一区二区三区在线播放| 一区二区三区久久网| 日韩视频免费观看| 中文一区在线| 久久国产精品久久w女人spa| 一本色道久久88精品综合| 亚洲视频精品| 欧美一区二区三区在线视频| 欧美一区影院| 男女精品网站| 日韩视频免费观看高清在线视频 | 午夜精品久久久久久久99热浪潮| 黄色成人在线免费| 亚洲精品影院| 午夜国产精品影院在线观看 | 国产欧美视频一区二区三区| 国内欧美视频一区二区| 先锋影音国产精品| 久久精品国产久精国产一老狼| 久久九九精品99国产精品| 欧美xx视频| 国产精品剧情在线亚洲| 国产在线精品成人一区二区三区| 亚洲电影av| 午夜精品久久久久久久久久久久久| 久久久91精品| 亚洲精品久久久一区二区三区| 亚洲免费视频在线观看| 久久久噜噜噜久久狠狠50岁| 欧美精品一区在线发布| 国产视频一区在线观看一区免费| 91久久精品一区| 欧美一区二区三区免费大片| 亚洲第一毛片| 久久先锋影音av| 国产精品一区亚洲| 在线观看91精品国产麻豆| 亚洲国产日韩欧美在线图片| 午夜激情一区| 99成人免费视频| 久久久欧美精品| 国产欧美日韩视频| 亚洲伊人网站| 亚洲三级免费| 夜夜嗨一区二区三区| 卡一卡二国产精品| 国产一区二区精品丝袜| 亚洲一区在线观看视频| 鲁鲁狠狠狠7777一区二区| 亚洲第一区在线观看| 午夜精品久久久久久久白皮肤 | 最新国产拍偷乱拍精品| 亚洲一区二区黄| 国产精品嫩草影院av蜜臀| 99这里只有久久精品视频| 亚洲激情网站免费观看| 久久全国免费视频| 亚洲国产精品久久久久| 久久在线观看视频| 久久综合综合久久综合| 在线不卡中文字幕| 亚洲视频在线观看一区| 制服丝袜激情欧洲亚洲| 欧美午夜不卡| 久久精品一区四区| 先锋影音一区二区三区| 亚洲第一天堂无码专区| 欧美国产精品v| 欧美日韩在线免费观看| 中文国产成人精品久久一| 亚洲午夜久久久| 国产日韩欧美自拍| 欧美高清视频一区| 亚洲国产欧美不卡在线观看| 欧美巨乳在线| 亚洲天天影视| 亚洲激精日韩激精欧美精品| 国产精品啊v在线| 99一区二区| 欧美一区日本一区韩国一区| 狠狠色丁香婷综合久久| 亚洲精选一区| 国产亚洲一区二区在线观看| 亚洲高清色综合| 欧美视频一区二区三区…| 亚洲欧美日韩一区二区| 亚洲精品一区二区三区av| 欧美成人精品影院| 在线不卡免费欧美| 欧美成人午夜免费视在线看片| 欧美一区二区三区四区在线| 国产精品夫妻自拍| 亚洲在线成人| 一本一本久久| 国产精品高清网站| 午夜激情综合网| 久久av一区二区| 久久精品主播| 亚洲天堂av电影| 久久大综合网| 亚洲视频精选| 一区二区精品在线观看| 欧美日韩123| 久久深夜福利免费观看| 国产精品麻豆成人av电影艾秋| 欧美电影在线| 亚洲成人在线| 亚洲免费综合| 午夜精品福利在线| 性欧美大战久久久久久久免费观看| 亚洲永久精品国产| 一区二区三区四区五区精品视频| 午夜精品久久| 中文一区二区在线观看| 欧美电影免费观看高清| 欧美一区二区私人影院日本| 久久国产加勒比精品无码| 亚洲欧美日韩天堂一区二区| 欧美v日韩v国产v| 久久夜色撩人精品| 国产目拍亚洲精品99久久精品| 每日更新成人在线视频| 国产视频不卡| 亚洲欧美国产高清va在线播| 久久aⅴ国产欧美74aaa| 国产精品高清网站| 欧美激情一区在线观看| 亚洲第一区色| 久久国产毛片| 欧美第一黄网免费网站| 国产亚洲精品久久久久久| 欧美在线免费观看亚洲| 久久九九热免费视频| 欧美高清自拍一区| 一本色道久久综合亚洲精品婷婷 | 亚洲视频大全| 国产精品久久久| 一本色道久久综合亚洲91| 亚洲制服欧美中文字幕中文字幕| 欧美日本韩国| 欧美好骚综合网| 亚洲精品美女在线观看播放| 亚洲肉体裸体xxxx137| 亚洲欧美视频| 鲁大师成人一区二区三区| 亚洲一区视频在线| 国产精品亚洲美女av网站| 亚洲亚洲精品在线观看| 欧美综合国产| 亚洲第一精品夜夜躁人人爽| 久久亚洲影音av资源网| 香蕉乱码成人久久天堂爱免费 | 影院欧美亚洲| 久久色在线播放| 麻豆av福利av久久av| 国产又爽又黄的激情精品视频| 久久久久久久久久久一区| 亚洲免费一在线| 在线成人黄色| 欧美片第1页综合| 欧美在线视频导航| 欧美成人69av| 欧美一区二区三区另类 | 美女图片一区二区| 亚洲乱码国产乱码精品精可以看 | 久久伊人免费视频| 欧美亚男人的天堂| 小处雏高清一区二区三区 | 欧美国产视频一区二区| 亚洲视频一二| 91久久精品国产91久久性色tv | 麻豆成人在线观看| 一区二区国产日产| 久久亚洲精品视频| 亚洲中字黄色| 亚洲第一精品电影| 韩日视频一区| 欧美性生交xxxxx久久久| 欧美国产一区在线|