• <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>
            隨筆 - 55  文章 - 15  trackbacks - 0
            <2012年2月>
            2930311234
            567891011
            12131415161718
            19202122232425
            26272829123
            45678910

            常用鏈接

            留言簿

            隨筆分類

            隨筆檔案

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            delegate,中文不知道怎么翻譯,姑且叫代理吧。

                  delegate 的概念其實早就出現,只不過我看到它的時候卻是在研究Windows 8時,查閱網上的資料,delegate應該是最先出現在.NET框架中,為的是解決函數指針的不安全性。
                  為什么說c++的函數指針不安全呢?想到函數指針你能想到什么?不錯,函數的地址,函數的入口點,然后呢?沒了,確實就是這些東西,函數指針即沒有表示這個函數有什么返回類型,也沒有指示這個函數有什么形式的參數,更沒有指示有幾個參數,你可以隨意轉換這個函數指針,函數指針是非安全的。
                  那么,既然要升級C++,那就為函數指針的安全性做點修改吧。你不是只有個地址嗎,沒關系,我給你封裝一下,封裝成一個類,這個類里面你想要的關于這個函數的所有信息都有,甚至這個函數被哪個對象調用我都封裝進去。好了吧。
                  同其他的類一樣,delegate就是一個數據結構,你可以在把它放在類中作為類的數據成員,也可以當成形參,其他類可以怎么折騰,你就可以怎么折騰,從此你就不是一個地址了,你也是可以和別人平起平坐的類了。哇哈哈,高興壞了。
                  言歸正傳,這里參考MSDN中的官方文檔來說明一下delegate:
                  原文鏈接地址:http://msdn.microsoft.com/en-us/library/windows/apps/hh441500(v=vs.110).aspx 

                  下面是一個delegate的聲明:如果你是在研究Windows 8 的話,^(姑且叫它hat吧)標識符你肯定比較關注,這是說明這個對象是Windows Runtime 類型的,這個對象不用你自己去release,他會采用引用計數技術,當你不需要的時候,后臺自動給你釋放掉,類似于Java的垃圾回收機制,其實就是把原來的COM中的Release方法給封裝了一下。言歸正傳,這個delegate聲明表示,它封裝了一個方法,這個方法的返回值是Platform::String^ ,參數也是Platform::String^(這個我就不解釋了,都是WinRT里面的新東西,大家WinRT稍微用用就會經常接觸這個東西,不同于std::string)
            下面又定義了一個借口,我們可以看到NormalizeZipCode^ normFunc可以作為形參。

                 下面我們定義一個類來實現這個接口:
             1 ref class ZipCodes: public IZipCodes
             2 {
             3 private:
             4   Platform::String^ LookupFromCityState(Platform::String^ city, Platform::String^ state);
             5   Platform::String^ Normalize(Platform::String^ zip);
             6 public:
             7   Platform::String^ ZipCodeFromCity(Platform::String^ city, Platform::String^ state,
             8     NormalizeZipCode^ normFunc)
             9   {
            10     auto zip = LookupFromCityState(city, state);
            11     NormalizeZipCode^ func = (normFunc != nullptr ? normFunc :
            12       ref new NormalizeZipCode(this, &ZipCodes::Normalize));//這里是重點,給func賦值,可以賦給它一個nullptr指針,也可以new一個給它。
            13     return func(zip);
            14   }
            15 };
                 我們看到這個ZipCode類實現了該接口,并實現了這個方法。我們可以這樣賦值:NormalizeZipCode ^ func = ref new NormalizeZipCode(&ZipCodes::Normalize);
                 調用嘛,大家也看到了,就直接用func(zip)就可以了,這時候,如果傳輸的normFunc是空值,那么就給func賦值為NormalizeZipCode(this&ZipCodes::Normalize) ,也就是說這時的func就是Normalize函數的代理了,可以直接用func(zip)來調用Normalize(。。。),或許這就是為什么這個類型為什么叫代理類型的原因吧。

                  使用上述的類和方法的時候,就跟其他類一樣,直接用就行了。
                  
             1 IZipCodes ^codes = ref new ZipCodes();
            2 auto func = ref new NormalizeZipCode([](Platform::String^ zipcode) {//lambda 表達式
            3     return "98103";
            4     });
            5 
            6 auto zip1 = codes->ZipCodeFromCity("Seattle", "WA", nullptr);//這里調用哪個?
            7 auto zip2 = codes->ZipCodeFromCity("Seattle", "WA", func);// 這里調用哪個?
            8 
                  上述的[]應該是lambda表達式,我沒有深究。有了解的朋友請給我補補。
            posted on 2012-02-14 15:19 Dino-Tech 閱讀(295) 評論(0)  編輯 收藏 引用
            亚洲午夜久久久久久噜噜噜| 久久综合九色综合欧美狠狠| 青青久久精品国产免费看| 久久精品无码一区二区日韩AV | 国产精品99久久久精品无码| 亚洲精品乱码久久久久久蜜桃图片| 久久久久成人精品无码中文字幕| 亚洲国产成人久久综合碰碰动漫3d | 久久精品国产99国产精品导航 | 性做久久久久久久久老女人| 欧洲精品久久久av无码电影| 久久国产精品波多野结衣AV| 久久精品中文字幕一区| 久久婷婷久久一区二区三区| 精品无码久久久久国产动漫3d| 国内精品伊人久久久久av一坑 | 亚洲国产成人久久精品99 | 精品久久国产一区二区三区香蕉| 日产精品99久久久久久| 久久涩综合| 久久国产精品免费一区二区三区| 欧洲精品久久久av无码电影| 青青草原综合久久大伊人| 久久国产综合精品五月天| 国产精品久久久久久影院| 午夜人妻久久久久久久久| 久久频这里精品99香蕉久| 久久国产影院| 久久久国产精品| 亚洲综合伊人久久综合| 久久国产欧美日韩精品| 亚洲国产综合久久天堂| 日日狠狠久久偷偷色综合0| 久久本道久久综合伊人| 97久久精品人人做人人爽| 免费观看久久精彩视频| 日韩一区二区久久久久久| 精品无码久久久久久国产| 欧美与黑人午夜性猛交久久久| 欧美粉嫩小泬久久久久久久 | 亚洲中文字幕无码久久综合网|