• <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久久不卡| 久久精品国产福利国产琪琪| 久久精品国产清自在天天线| 欧美成a人片免费看久久| 久久精品国产精品亚洲精品| 996久久国产精品线观看| 久久精品国产精品青草| 久久综合久久伊人| 日韩人妻无码一区二区三区久久 | 国产精品伊人久久伊人电影| 久久婷婷色综合一区二区| 伊人久久大香线蕉综合影院首页| 国产精品久久久久天天影视| 久久亚洲国产最新网站| 久久免费精品一区二区| 精品久久久无码人妻中文字幕| 26uuu久久五月天| 国产精品99精品久久免费| 久久久久久久91精品免费观看 | 久久av免费天堂小草播放| 日韩久久久久久中文人妻| 久久久久综合国产欧美一区二区| 性高湖久久久久久久久| 色综合合久久天天给综看| 国产成人99久久亚洲综合精品| 亚洲午夜久久久影院| 伊人精品久久久久7777| 久久久久亚洲AV成人网人人软件| 国产综合久久久久| 乱亲女H秽乱长久久久| 色婷婷久久综合中文久久蜜桃av| 影音先锋女人AV鲁色资源网久久 | 亚洲精品无码专区久久同性男| 国产精品成人99久久久久91gav| 99久久精品国产高清一区二区 | 香港aa三级久久三级| 国产精品一区二区久久精品| 久久ww精品w免费人成| 日韩精品久久无码人妻中文字幕| 午夜精品久久久久久久| 久久久久亚洲av无码专区喷水 |