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

隨筆-341  評論-2670  文章-0  trackbacks-0

    已經(jīng)忘了是去年還是前年聽到微軟說要在C# 3.0里為C#添加lambda表達式,與此同時Java的團隊也一直在說想為Java添加lambda表達式。到了今天,C#似乎已經(jīng)把這個特性加進去了,Java還沒有。Java說這個特性還在計劃列表之中,不過暫時可以使用匿名類來代替。想必是因為在Java中表示函數(shù)指針的方法比較奇怪罷……

    其實無論是lambda表達式(事實上應(yīng)該叫匿名函數(shù))或是匿名類,都能歸屬到一種叫閉包的東西上面。閉包原來是代數(shù)中的用語,只是那些研究理論的老大們覺得這玩意兒也能拉到“閉包”里面去,于是就叫閉包了。匿名函數(shù)原本是丘奇發(fā)明的一個lambda-calculus的其中一部分,后來計算機的老大們突然發(fā)現(xiàn)lambda-calculus非常適合用來充當(dāng)程序設(shè)計語言的模型,于是就對它進行了非常多的擴充,還弄了個什么類型理論出來。好像扯遠(yuǎn)了。

    想象一下如下使用閉包的代碼:

    MyClosure=func(Number1)
    {
        return func(Number2)
        {
            return Number1+Number2;
        };
    };

    a=MyClosure(1);
    b=MyClosure(2);
    writeln(a(10));
    writeln(b(10));

    輸出的結(jié)果是11和12。MyClosure函數(shù)接受一個參數(shù),返回一個新的函數(shù)。新的函數(shù)將MyClosure的參數(shù)與自己的參數(shù)相加,返回結(jié)果。我們會看到a和b在接受相同的參數(shù)的時候,產(chǎn)生了不同的結(jié)果。所以實際上MyClosure返回的內(nèi)部函數(shù)已經(jīng)把MyClosure的參數(shù)“記下來”了。所以在具有閉包功能的語言,函數(shù)不能僅僅用一個函數(shù)指針來表示,還需要一些其他的東西。

    考察一下a(10)的運行過程。首先程序?qū)?shù)10傳遞給閉包a,閉包a接收到參數(shù)之后,執(zhí)行代碼“return Number1+Number2;”此時Number2必然是10,但是Number1是什么呢?要找。在一般的語言里,函數(shù)的參數(shù)都是放在堆棧的。如果閉包也將參數(shù)放在堆棧的話,那么Number1在MyClosure運行結(jié)束的時候就會消失掉,這個時候a(10)再通過堆棧去搜索Number1顯然就是不可能的。既然“參數(shù)放在堆棧”導(dǎo)出了矛盾,那么參數(shù)也就不能放在堆棧了。放在哪里呢?需要一張表。

    對于形式化有所了解的人應(yīng)該立刻能想到解決的辦法了。因為有關(guān)形式化的讀物在描述對一個名字進行求值的時候使用的方法是“在環(huán)境中通過名字搜索出一個指向某空間的引用”。如果我們可以在運行的時候一邊跑代碼,一邊建立一張變量表附著在閉包上的話,這個問題就能夠順利解決了。那怎么做呢?

    可以想象一下在程序執(zhí)行的過程之中有一張全局的表,表內(nèi)放了若干變量(MyClosure,a,b,writeln)。MyClosure在返回內(nèi)部函數(shù)的時候,將全局的表跟自己的參數(shù)構(gòu)成的表聯(lián)通內(nèi)部函數(shù)的指針一起傳遞給變量a(或者b)。內(nèi)部函數(shù)看得見Number1,全局部分卻看不見Number1,因此我們可以知道在程序的執(zhí)行過程中,表并不只有一張。那么一張表加上一張表還是等于一張表,所以表本身是遞歸的。我們可以用一個鏈表來實現(xiàn)它。


    現(xiàn)在知道了表的結(jié)構(gòu)之后,讓我們看一下程序的執(zhí)行過程中究竟發(fā)生了什么事情。現(xiàn)在我們定義一張全局表global,global在剛開始的時候僅僅有writeln一項。執(zhí)行了MyClosure=func...的時候global添加了MyClosure,執(zhí)行到a=MyClosure(1)的時候,MyClosure內(nèi)部構(gòu)造了一張表鏈接到global身上,我們把這張表命名為internal。程序如果能夠訪問internal就能夠訪問global,反之不可。所以外部的代碼連接到的環(huán)境節(jié)點是global,而MyClosure里面的東西鏈接到的節(jié)點是internal -> global。這個時候閉包已經(jīng)構(gòu)造好了,其結(jié)構(gòu)是<內(nèi)部函數(shù)的指針,internal->global>。這個時候a=MyClosure(1)已經(jīng)執(zhí)行完畢了,global添加了a。

    現(xiàn)在,global=(writeln,MyClosure,a),internal=(Number1)->global。a附帶的環(huán)境是internal。同理,b也執(zhí)行完畢,b得到的表是internal2=(Number1)->global。a和b具有兩張不同的表internal和internal2,但是它們都連接到了global身上,因此可以共同訪問到相同的MyClosure、a、b和writeln,但是訪問到的Number1確是不同的。

    于是執(zhí)行a(10)和b(10)能夠訪問不同的結(jié)果的機制也就很明朗了。調(diào)用a和b的時候,他們各自通過自己的Number2與自己附帶的表的Number1相加。10+internal[Number1]=10+1=11,10+internal2[Number1]=10+2=12。這個時候我們發(fā)現(xiàn),MyClosure的參數(shù)Number1并不在堆棧上面,而在不同的internal和intenral2上。這就是為什么用有閉包的語言,函數(shù)的參數(shù)不能放進堆棧的原因。因為堆棧的作用僅僅跟寄存器相似——用來保存臨時數(shù)據(jù),而不能用來保留整個call stack上的函數(shù)的參數(shù)。

    好像聽微軟說過,C#并不存在堆棧?好象是吧……
posted on 2008-04-20 21:55 陳梓瀚(vczh) 閱讀(7725) 評論(5)  編輯 收藏 引用 所屬分類: 腳本技術(shù)

評論:
# re: 如何實現(xiàn)語言中的閉包(Closure) 2008-10-06 23:15 | Kenny Yuan
閉包的概念映射其實挺直接的,至少我這么認(rèn)為
比如transitive closure的概念,非常直接  回復(fù)  更多評論
  
# re: 如何實現(xiàn)語言中的閉包(Closure) 2008-12-16 09:04 | 小不點
能不能理解成 用數(shù)據(jù)庫保存的樣式,比如當(dāng)a=MyClosure(1);的時候在數(shù)據(jù)庫樣的表里存入MyClosure和1,返回一個數(shù)據(jù)庫的唯一標(biāo)識,把他賦值給a,調(diào)用的時候 直接用a的參數(shù),加上用a找數(shù)據(jù)庫表中保存的1呢?
沒用過c#,只是看到你文章自己的一點理解~  回復(fù)  更多評論
  
# re: 如何實現(xiàn)語言中的閉包(Closure) 2008-12-16 18:59 | 陳梓瀚(vczh)
你說的只是一個部分,其實需要保存的東西還有很多。不過這么理解也算是可以的。  回復(fù)  更多評論
  
# re: 如何實現(xiàn)語言中的閉包(Closure) 2008-12-16 19:15 | 小不點
對,我只是打個比方,那么如果一個程序運用相當(dāng)多的閉包,也就是用這種函數(shù),那么保存的數(shù)據(jù)就狠狠多了,占用的內(nèi)存控件就不得而知了~,高手能指點下么?  回復(fù)  更多評論
  
# re: 如何實現(xiàn)語言中的閉包(Closure) 2008-12-16 20:09 | 陳梓瀚(vczh)
結(jié)果就是會多占用內(nèi)存了。至于怎么計算,這是很難的……  回復(fù)  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美视频在线观看一区| 亚洲欧美清纯在线制服| 欧美一区91| 午夜精品理论片| 欧美一区二区播放| 久久精品免费看| 免费在线观看精品| 亚洲三级免费| 亚洲激情在线激情| 日韩一级精品| 午夜在线观看欧美| 久久深夜福利免费观看| 欧美va亚洲va日韩∨a综合色| 欧美国产欧美亚洲国产日韩mv天天看完整| 欧美国产成人精品| 国产日韩精品一区观看| 亚洲国产精品一区二区三区| 中文一区二区在线观看| 久久精品国产在热久久| 亚洲国产成人在线视频| 亚洲性视频h| 男人插女人欧美| 国产精品嫩草99a| 亚洲国产日韩欧美综合久久 | 麻豆精品一区二区综合av| 欧美精品一区二区视频| 国产啪精品视频| 日韩午夜视频在线观看| 久久久久成人精品免费播放动漫| 亚洲黄色有码视频| 久久精品国产77777蜜臀| 欧美日韩午夜在线| 亚洲福利视频专区| 欧美在线视频二区| 韩国精品在线观看| 99精品国产在热久久| 久久久青草婷婷精品综合日韩 | 欧美亚洲免费在线| 欧美精品久久一区二区| 国产一区二区按摩在线观看| 亚洲深夜av| 欧美激情五月| 久久精品国产免费| 国产女精品视频网站免费 | 性一交一乱一区二区洋洋av| 欧美国产日韩xxxxx| 性久久久久久久久久久久| 欧美日韩亚洲综合| 亚洲靠逼com| 欧美激情一区二区三区蜜桃视频| 欧美在线视屏| 国产区亚洲区欧美区| 亚洲欧美日韩中文播放| 99国产一区| 欧美日韩成人在线播放| 亚洲精品一区二区三| 欧美成人午夜视频| 另类尿喷潮videofree| 韩国av一区| 久久中文字幕一区| 久久经典综合| 在线不卡免费欧美| 另类激情亚洲| 久热这里只精品99re8久| 亚洲高清免费在线| 亚洲国产精品99久久久久久久久| 免费成人小视频| 亚洲精品中文字幕女同| 亚洲人成网站在线播| 欧美精品在线播放| 亚洲一区二区在线免费观看视频| 一区二区三区波多野结衣在线观看| 欧美日韩在线影院| 欧美在线观看天堂一区二区三区 | 卡一卡二国产精品| 久久一区亚洲| 99国产精品视频免费观看| 亚洲精品欧美一区二区三区| 欧美日韩免费一区| 欧美在线视频日韩| 久久五月天婷婷| 日韩视频免费在线| 亚洲深夜激情| 黄色日韩网站| 亚洲欧洲另类国产综合| 国产精品第一页第二页第三页| 欧美一区二区视频97| 鲁大师影院一区二区三区| 99国产麻豆精品| 欧美在线亚洲在线| 亚洲另类在线一区| 久久婷婷综合激情| 嫩草伊人久久精品少妇av杨幂| 一卡二卡3卡四卡高清精品视频| 亚洲性视频网站| 亚洲高清视频的网址| 日韩网站在线| 激情欧美一区二区三区在线观看 | 久久国产一区二区三区| 亚洲人成网站色ww在线| 亚洲性视频网址| 亚洲日本电影| 午夜精品亚洲| 99视频+国产日韩欧美| 欧美与欧洲交xxxx免费观看| 99精品国产热久久91蜜凸| 久久黄色影院| 亚洲亚洲精品在线观看| 久久视频这里只有精品| 亚洲自拍偷拍一区| 嫩模写真一区二区三区三州| 久久国产欧美| 欧美午夜精品久久久久久人妖| 鲁大师成人一区二区三区 | 国产精品丝袜xxxxxxx| 亚洲高清久久网| 国内精品国语自产拍在线观看| 一本色道久久综合亚洲精品婷婷| 亚洲春色另类小说| 久久黄金**| 久久国产精品久久国产精品| 欧美性猛交xxxx免费看久久久| 欧美激情精品久久久久久蜜臀 | 亚洲精品国产拍免费91在线| 国内自拍一区| 性欧美大战久久久久久久免费观看 | 亚洲黄色成人久久久| 韩日欧美一区| 欧美一区二区免费观在线| 亚洲欧美日韩精品综合在线观看| 欧美理论电影在线播放| 亚洲人成绝费网站色www| 91久久国产自产拍夜夜嗨| 久久女同互慰一区二区三区| 久久婷婷影院| 在线不卡中文字幕播放| 久久综合激情| 欧美激情成人在线| 99re6这里只有精品| 欧美激情在线观看| 亚洲精品久久久蜜桃| 99伊人成综合| 欧美人妖另类| 亚洲网在线观看| 久久精品二区| 在线日韩日本国产亚洲| 欧美国产第一页| 99re成人精品视频| 国产亚洲免费的视频看| 亚洲欧美综合| 久久久噜噜噜久久中文字幕色伊伊 | 亚洲国产精品成人一区二区| 亚洲人成77777在线观看网| 欧美精品在线视频观看| 日韩写真在线| 欧美一级淫片aaaaaaa视频| 国产一区二区三区四区| 久久夜色精品国产| 亚洲精品美女久久久久| 午夜久久99| 在线播放中文一区| 欧美久久99| 香蕉久久精品日日躁夜夜躁| 猫咪成人在线观看| 一区二区电影免费观看| 国产精品推荐精品| 久久在线免费观看| 亚洲图片激情小说| 欧美成人免费全部观看天天性色| 一二三区精品| 国产在线精品二区| 欧美日韩久久| 久久国产日韩欧美| 99热精品在线| 久久一区中文字幕| 亚洲综合大片69999| 亚洲大片免费看| 欧美四级在线| 卡通动漫国产精品| 亚洲欧美日韩一区二区三区在线| 亚洲成人自拍视频| 久久精品亚洲| 亚洲在线免费视频| 亚洲精品欧美极品| 激情成人av在线| 国产精品毛片在线| 欧美日韩国产综合久久| 久久艳片www.17c.com| 亚洲欧美久久久| 一本色道久久综合狠狠躁的推荐| 开元免费观看欧美电视剧网站| 亚洲综合国产精品| 一区二区三区四区五区在线| 亚洲国产精品一区在线观看不卡 | 亚洲精品影院| 伊人久久大香线| 国产农村妇女毛片精品久久莱园子| 欧美黑人一区二区三区| 久久在线91| 久久久久久综合|