• <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
            <2013年1月>
            303112345
            6789101112
            13141516171819
            20212223242526
            272829303112
            3456789

            常用鏈接

            留言簿

            隨筆分類

            隨筆檔案

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            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 閱讀(297) 評論(0)  編輯 收藏 引用
            精品国产乱码久久久久久呢| 久久国产精品99久久久久久老狼| 久久露脸国产精品| 亚洲AV日韩AV永久无码久久| 久久香蕉综合色一综合色88| 久久人人爽人人爽人人片av麻烦 | 亚洲AV无码久久| 久久亚洲精品视频| 午夜久久久久久禁播电影| 精品久久久久久无码人妻蜜桃| 日本久久中文字幕| 9191精品国产免费久久| 无码超乳爆乳中文字幕久久 | 四虎国产精品免费久久| 久久这里只有精品久久| 久久精品夜夜夜夜夜久久| 久久精品国产精品亚洲| 久久亚洲综合色一区二区三区| 综合网日日天干夜夜久久| 三级片免费观看久久| 国产精品日韩欧美久久综合| 久久国产免费观看精品3| 性色欲网站人妻丰满中文久久不卡| 99精品久久久久久久婷婷| 国产亚洲美女精品久久久久狼| 欧洲精品久久久av无码电影| 一本色道久久综合| 97视频久久久| 狠狠精品久久久无码中文字幕| 日韩影院久久| 精品国产日韩久久亚洲 | 亚洲中文字幕无码久久综合网| 亚洲婷婷国产精品电影人久久| 成人精品一区二区久久| 国产69精品久久久久9999| 国产精品一区二区久久精品无码| 91久久精一区二区三区大全| 国产精品久久永久免费| 91秦先生久久久久久久| 久久国产视频网| 久久无码专区国产精品发布|