• <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>

            天秤座的唐風

            總會有一個人需要你的分享~!- 唐風 -

              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
              13 隨筆 :: 0 文章 :: 69 評論 :: 0 Trackbacks

            std::initializer_list in C++0x

            作者:唐風
            原載:www.shnenglu.com/liyiwen
            轉載請注明出處

             在VC2010中,在語言核心方面增加了五個C++0x的特性:lambda、auto、static_assert、decltype、rvalue。
                有點遺憾的是沒有 std::initializer_list(其實遺憾的還有很多,只怪C++0x來得太晚,呵呵)。
                std::initializer_list 帶來的方便性是不言而喻的,它可以讓標準容器庫的使用變得更加的方便:
                在以前,我們使用一個容器,只能這樣做:

            int a[] = {0123};
            std::vector
            <int> vec(a, a+sizeof(a));

             或是:

            std::vector<int> vec;
            vec.push_back(
            1);
            vec.push_back(
            3);
            vec.push_back(
            3);
            vec.push_back(
            2);


                這樣很不美觀,也很不方便,如果要初始化的值很多,就會拖得很長,當嵌套使用容器類的時候就更麻煩了。這也使得容器對象在做 const 值使用時非常不方便,因為它的初始化很成問題。

             C++0x 中加入了 std::initializer 之后,這一問題就可以得到解決。
                我們以后可以這樣寫:

            std::vector<int> vec = {0235};


                統一又很簡潔。贊!(早就應該這樣了!呵呵)

             假設我有一個類,其中有需要一個“查詢器”,根據不同人的名字得到生日(字符串),我們可以這么寫:

            class Test {

            private:
                
            static std::map<stringstring> const nameToBirthday = {
                    {
            "lisi""18841011"},
                    {
            "zhangsan""18850123"},
                    {
            "wangwu""18870908"},
                    {
            "zhaoliu""18810316"},
                };
            }


                這樣,這個對象的聲明和定義都在一起,非常清晰,寫法也簡單。在成員函數中可以直接使用這個 map 的對象來進行查詢。如果在 C++98/03 ,要實現這個就要麻煩很多。
                注意,結合 C++0x 中新增的初始化方法,以后就算不是 static const 的成員也可以用這樣的初始化形式了。

             這種初始化語法的是依靠使用 std::initializer_list<T> 類來實現的。
                比如 vector ,會提供這樣的一個構造函數:

            template <typename T>
            vector::vector(std::initializer_list
            <T> initList);


                這個 std::initializer_list<T> 類也像 STL 容器類一樣,也提供迭代器,可以遍歷其中的內容。
                但與普通的容器類不一樣的是,這個類是“一等公民”(first-class),由只能用{}這個語法進行初始化,而且只能由編譯器來構建。構建成功就不能再改變(像 const ,呵呵),可以拷貝它,但所有拷貝實質上都是以引用方式進行的。
                由于 std::initializer_list 是一個類,所以不局限在構造函數中使用,普通的函數也可以使用,像這樣:

            void DealWithAll(std::initializer_list<int> intList) {
                
            for (auto i: intList) {  // print all number
                    cout
            <<i<<endl;
                }
                unsigned int count 
            = 0;
                
            // count for the odd numbers in the list, you can use std::count too.
                for_each (intList.begin(), intList.end(), [
            &count](int& a) {
                    
            if (a % 2) {
                        
            ++count;
                    }
                })
            }

            int main(void) {
                DealWithAll({
            1,2,3,4,5,6,7,8,9}); // you can call DealWithAll like this.
            }

             

            PS:
                呵呵,寫來寫去,發現 C++0x 反而越來越不像 C 了,嗯,也確實不需要太像 C ,C++ 就是 C++ ,希望 C++0x 能給 C++ 帶來新的生命力。

             

            posted on 2009-07-26 14:59 唐風 閱讀(5692) 評論(4)  編輯 收藏 引用 所屬分類: 語言技術

            評論

            # re: std::initializer_list in C++0x 2009-08-25 20:58 YESHG!
            原來你每天都在研究這些新特性啊……  回復  更多評論
              

            # re: std::initializer_list in C++0x 2009-08-25 22:33 唐風
            @YESHG!
            花個幾天時間看下Wiki上的條目就OK啦,不用每天研究,哈哈。。

            新版的C++在“易用性”上有了不少改進。
            但對于C++,我最想的是能有好、符合標準的C++編譯器支持各種嵌入式器件。  回復  更多評論
              

            # re: std::initializer_list in C++0x 2009-08-26 23:12 YESHG!
            我個人覺得語言夠用就可以勒,對新特性興趣不大啊...
            還是年輕人好啊,嘿嘿  回復  更多評論
              

            # re: std::initializer_list in C++0x 2009-08-27 08:55 唐風
            @YESHG!
            “夠用”是好,“好用”那就更好啦!呵呵
            這次的新標準是經過10年沉淀的結果,自然散發出很成熟和理性的氣息。
            雖然不可能做到完美,但也非常出色了。

            以后我們再使用std::map,結合著new for loop和auto,就會覺得它和python中的Dict一樣的方便和好用。感覺有點動態的味道!

            再沒有lambda之前,std::for_each之類的泛型算法有如雞肋,boost::lambda的實現又過于復雜使人望而生畏。現在好了,我們可以自由地“在線”定義函數。這會促進更多的更好的泛型代碼出現并廣泛應用。也就促進了抽象和重用。  回復  更多評論
              

            99久久精品免费看国产一区二区三区| 久久久久这里只有精品| 国产精品内射久久久久欢欢| 国产69精品久久久久久人妻精品| 久久精品国产99国产精品澳门| 久久成人小视频| 久久se精品一区二区影院 | 99久久99久久精品国产片| 亚洲精品国产字幕久久不卡| 久久国产午夜精品一区二区三区| 久久99久久99精品免视看动漫| 久久精品中文字幕大胸| 国产精品九九久久精品女同亚洲欧美日韩综合区 | 佐藤遥希在线播放一二区 | 午夜精品久久久久成人| 99热成人精品免费久久| 好属妞这里只有精品久久| 久久亚洲精品成人av无码网站| 思思久久99热只有频精品66| 久久综合九色欧美综合狠狠| 国产成人久久精品麻豆一区| 久久九九亚洲精品| 国产精品久久久久影院嫩草| 久久久久免费看成人影片| 伊人久久大香线蕉av不卡| 亚洲国产成人乱码精品女人久久久不卡| 99久久99久久精品国产片| 午夜不卡888久久| 热99re久久国超精品首页| 久久成人国产精品二三区| 1000部精品久久久久久久久| 人妻少妇久久中文字幕| 久久免费的精品国产V∧| 少妇久久久久久久久久| 亚洲精品无码久久久影院相关影片| 久久精品桃花综合| 青青草原综合久久大伊人| 国产精品成人久久久| 久久精品国产99国产精品导航| 久久精品人人做人人爽电影| 无码人妻久久久一区二区三区 |