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

歲月流轉,往昔空明

C++博客 首頁 新隨筆 聯系 聚合 管理
  118 Posts :: 3 Stories :: 413 Comments :: 0 Trackbacks
在進行靜態強類型語言的設計過程中,是一定需要提供一種語法實現變量和類型的關聯。這種語法一般稱之為 “聲明” 或者 “定義”。

如果用一種人類易讀的方式進行表達,可以寫作 define variable_name as type_name。沒有錯,你看到的這種形式類似于VB當中 Dim As的方法。在語法分析的過程中,這種方法的好處很明顯。define 作為提示字,意味著一個聲明或者定義的開始,as 則代表后續的Tokens都是用于一個類型的,這樣關鍵字可以很顯著的將語義區分開。

但是這種寫法并不方便。C 一類的語言,都選用一種 prefix declaration specifier 的方式,也就是我們常常見到的:type_name variable_name 這樣的形式。舉個最簡單的例子,int i;。如果有類型修飾,可以作為一個基本類型的前綴或者后綴出現。例如const int i; 或者 int const i; 至于修飾含義是左綁定還是右綁定,這個需要取決于語言本身的設計。

如果事情是這個樣子的話,也就沒什么好說的了。但是在C語言里面,有兩個例外:函數和數組。例如,在C里面定義一個數組,寫作:const int array[expr]; 這種寫法既不是前綴寫法,也不是后綴寫法。類型被變量兩分了。如果僅僅是一個數組定義,那也好辦,當做特殊情況處理就好了。
但是有時候我們的數組元素會變得非常復雜。 舉個例子,( struct {...} const [ constant ] identifier ( params... )  ) [ expr ]。你能理解這樣一個復雜的定義其實是一個函數的數組么?不僅僅是你不能,我想在撰寫語法規則的時候,又困難,又不合邏輯。

在C的EBNF中,這個問題解決起來也很復雜。
在這里,我們簡化一下C的語法,不考慮C的指針,不考慮變量初始化,不考慮類型修飾符,也不考慮一個類型定義多個變量的情況。
這就意味著你只能寫 int i; int j; j = 0; 而不能寫 int i, j = 0;

declaration ::= declaration_specifier declarator

declarator ::= identifier
               | delcarator '['  expr ']'
               | declarator '(' parameters_declaration_list ')'
               | '(' declarator ')'


那么我問你,declarator是個什么東西。變量名?不是。函數聲明?也不是。數組?也不是。declaration_specifier呢?變量類型?是。數組元素類型?是。函數返回值類型?也是。顯然這樣一個語法要素具備了太多的語義。更重要的是,沒到最后,你是沒法確定declaration_specifier究竟是一個什么含義,identifier所代表的,究竟是個什么東西。顯然只有在聲明匹配完成之后,還需要進行復雜的推導過程,才能確定變量的嵌套結構。

這個問題還導致了C語言里面的這么一個特性:那就是很出名的指針符號*的變量綁定性質。在C語言中,*,[],() 操作符并沒有理解為對類型的修飾,而是理解為對變量的修飾。這就讓我們必須要這么寫: int m[expr], n[expr]; int m( int, int ), n( int, float );
而對變量,寫法就成了: int x, y; 這導致了同樣的寫法兩者在語義上的不一致性。這也是為什么新手云里霧里的根本原因了。按照普通變量的規矩,函數應該寫成 int (x, y) (int);這樣的結構。好吧,這樣還挑戰不倒你。但是如果我更復雜一點,加上初始化呢?就變成了 int ( x = p0, y ) (int) 這樣的結構,呃。

為什么C會這么做?難道完全的前置類型會讓語法分析工作變難么?很顯然不會。雖然C語言如此聲明的出發點不可考,但是想讓普通類型和數組聲明維持同樣的語法結構是很簡單的事情,C#就給了一個很好的答案。在C#中,變量是如此聲明的:

declaration ::= declaration_specifier declarator
declaration_specifier ::= function_specifier | array_specifier | identifier
                          | '(' declaration_specifier ')'
function_specifier ::= declaration_specifier '(' parameter_declaration_list ')'
array_specifier ::= declaration_specifier '[' expression_list ']'


這樣,declaration_specifier完全就變成了類型,而declarator部分就和類型脫鉤了。在這種聲明方式中,我們就這么定義一個變量 int [] x, y, z; OK,這樣大家就理解了,x,y,z都是一個數組。而不會造成C語言當中的誤解。

最后討論一下類型修飾的問題。這里只討論單一類型的類型修飾,下面我們會看到,復合類型其實也是一樣的。我們將類型聲明和表達式進行類比,就可以將類型理解為變量,類型修飾理解為單目操作符。

const type  <==類比==>  ~var

const就相當于按位取反操作符~,type就相當于var。const type這個表達式的結果就是一個常量化的type。那么,我們可以更廣泛的將聲明理解成 type_expression variable_name 這樣的形式。type_expression在語義分析的時候進行類型演算得出結果,variable_name則利用類型表達式獲得真正的類型,并實例化。下面我們寫出type_expression的演算語法:

type_expression ::= type_identifier
                    | type_op type_expression  /* prefix  style */
                    | type_expression type_op  /* postfix style */
type_op ::= type_qualifier

當然,對于 const int volatile 這樣的聲明,這個表達式還有二義性。這個二義性可以通過一定的方法消除,這一點一般的編譯原理教材都有詳細的討論。并且,我們完全可以將()和[]也納入到type_operator中,這兩個操作一個可以構造出函數類型,一個構造出數組類型來,這樣類型問題就得到了一個遞歸一致的解決。

當然,更重要的是,我將type_expression variable_name這樣的聲明式變成typedef type_expression variable_name呢?

哈哈。

最后嚴重感謝一下VCZH,因為這小子吃了足夠的shit,我就可以不用繼續吃shit了。正所謂前人栽樹后人乘涼。

posted on 2009-02-25 01:33 空明流轉 閱讀(1989) 評論(2)  編輯 收藏 引用

評論

# re: 靜態強類型語言的類型聲明與變量聲明 2009-02-25 01:43 陳梓瀚(vczh)
囧  回復  更多評論
  

# re: 靜態強類型語言的類型聲明與變量聲明[未登錄] 2009-02-27 09:37 六水
哈哈,這句說的太經典了  回復  更多評論
  


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产亚洲一区二区在线观看| 亚洲视频在线观看视频| 久久久噜噜噜久噜久久| 香蕉久久国产| 久久精品人人做人人爽电影蜜月| 欧美影院成人| 久久久国产精品亚洲一区| 久久久精品午夜少妇| 免费成人毛片| 欧美女同视频| 国产精品视频专区| 国产在线精品二区| 在线观看的日韩av| 99视频国产精品免费观看| 亚洲性图久久| 欧美精品一区二区在线观看| 欧美视频一区二区三区…| 国产欧美欧美| 亚洲欧洲精品成人久久奇米网| 亚洲国产成人精品久久久国产成人一区| 欧美一区二区免费视频| 久久精品视频免费| 欧美激情网友自拍| 一区二区三区高清| 久久成人免费| 欧美激情视频在线免费观看 欧美视频免费一| 欧美精品综合| 国产麻豆精品theporn| 亚洲福利专区| 午夜精品免费在线| 亚洲激情小视频| 一区二区三区高清在线观看| 久久精品国产一区二区三区| 欧美日韩一区二区三区在线 | av成人老司机| 久久久国产精品一区| 亚洲精品裸体| 久久精品亚洲乱码伦伦中文| 欧美视频三区在线播放| 亚洲电影第三页| 久久福利电影| 一本大道av伊人久久综合| 午夜免费久久久久| 亚洲美女毛片| 欧美91大片| 在线成人av网站| 久久九九电影| 性欧美1819sex性高清| 欧美午夜影院| 一本色道久久加勒比精品| 欧美国产另类| 欧美在线视频免费播放| 国产精品久久久久秋霞鲁丝 | 亚洲一区二区三区在线视频| 欧美电影在线观看完整版| 一区二区三区在线观看欧美| 久久精品一区二区| 香蕉久久精品日日躁夜夜躁| 国产精品你懂的在线| 亚洲一区美女视频在线观看免费| 亚洲区一区二| 欧美日韩国产一区二区| 妖精成人www高清在线观看| 欧美1级日本1级| 麻豆精品一区二区综合av | 99爱精品视频| 欧美www在线| 美女国内精品自产拍在线播放| 亚洲欧美中文字幕| 欧美成人首页| 麻豆国产精品一区二区三区| 最新日韩在线| 亚洲人成网站在线播| 欧美日韩在线视频一区| 亚洲欧美日产图| 午夜精品一区二区三区在线播放| 国产精品影院在线观看| 久久精品免费观看| 久久久久久久久久久成人| 亚洲二区在线观看| 日韩视频在线一区二区| 国产精品一卡| 欧美成人免费视频| 欧美日韩一区二区在线视频| 亚洲性线免费观看视频成熟| 午夜视频精品| 亚洲国产精品一区| 在线视频一区二区| 狠狠干综合网| 亚洲精品久久久久久久久| 国产精品狼人久久影院观看方式| 欧美一区2区视频在线观看| 久久久久久久尹人综合网亚洲| 亚洲国产乱码最新视频 | 久久精品一区二区三区不卡牛牛| 亚洲国产成人精品久久久国产成人一区| 亚洲国产精品一区在线观看不卡| 欧美日韩一区二区三区免费| 久久久精品国产免大香伊| 久久综合免费视频影院| 亚洲一区不卡| 蜜桃av一区| 欧美中文日韩| 欧美日韩视频在线第一区| 免费观看久久久4p| 国产精品国产精品国产专区不蜜| 麻豆精品视频在线观看| 欧美三日本三级少妇三99 | 亚洲午夜在线观看视频在线| 韩国av一区二区三区四区| 99视频在线观看一区三区| 激情欧美丁香| 亚洲一区视频| 亚洲伦理自拍| 久久九九精品99国产精品| 亚洲欧美中文日韩v在线观看| 欧美成人亚洲| 模特精品在线| 国产亚洲一区二区三区在线观看| 夜夜爽夜夜爽精品视频| 亚洲精品久久久久久久久久久久| 欧美一区在线直播| 午夜精品一区二区三区在线视 | 欧美一区激情视频在线观看| 欧美日韩1区2区| 亚洲国产精品嫩草影院| 亚洲成人资源网| 久久久久99| 久久欧美中文字幕| 久久久精品国产免费观看同学| 欧美日韩亚洲一区二区三区| 欧美黄色免费网站| 在线观看欧美成人| 久久免费99精品久久久久久| 欧美制服第一页| 国产欧美在线视频| 亚洲欧美在线aaa| 欧美一区1区三区3区公司| 国产嫩草一区二区三区在线观看| 亚洲天堂av高清| 性欧美在线看片a免费观看| 欧美午夜在线一二页| 日韩亚洲国产精品| 亚洲影院色无极综合| 国产精品xxx在线观看www| 亚洲视频欧洲视频| 久久国产精品久久久久久久久久| 国产日韩欧美夫妻视频在线观看| 亚洲综合激情| 久久精品首页| 亚洲大片在线| 欧美美女日韩| 亚洲一区二区三区在线| 久久久国产午夜精品| 亚洲大片在线| 欧美日韩三区| 性欧美长视频| 亚洲电影网站| 亚洲欧美在线一区| 在线日韩日本国产亚洲| 久久久水蜜桃av免费网站| 亚洲国产清纯| 欧美一级一区| 亚洲丶国产丶欧美一区二区三区| 欧美三级精品| 久久久999精品视频| 亚洲精品乱码久久久久久黑人 | 亚洲人被黑人高潮完整版| 欧美巨乳波霸| 亚洲欧美综合网| 亚洲国产精品美女| 欧美自拍丝袜亚洲| 亚洲精品美女在线观看播放| 国产精品久久久99| 久久中文精品| 中文亚洲视频在线| 欧美大胆成人| 亚洲欧美国产一区二区三区| 1024日韩| 国产精品免费电影| 欧美高清视频一区二区| 亚洲综合999| 亚洲黄色在线看| 久久青青草综合| 亚洲欧美色婷婷| 亚洲欧洲一区二区在线播放| 国产情侣久久| 欧美日韩高清区| 久久久天天操| 欧美一区二区高清在线观看| 一本色道久久综合亚洲精品按摩| 欧美11—12娇小xxxx| 欧美一乱一性一交一视频| 夜夜嗨一区二区三区| 亚洲第一精品电影| 最近看过的日韩成人| 久久久综合网站| 欧美午夜无遮挡| 欧美激情精品久久久久久久变态 | 亚洲国产女人aaa毛片在线|