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

            小明思考

            高性能服務器端計算
            posts - 70, comments - 428, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            C++編譯期Constraints設計

            Posted on 2006-01-17 14:12 小明 閱讀(1562) 評論(0)  編輯 收藏 引用 所屬分類: C/C++
            所謂的compile-time Constraints就是在編譯期使用C++的語法規則對設計進行約束檢查,盡量在編譯期把程序的問題暴露出來,節省成本。

            常用的規則:
            1.大小為0的數組在編譯期會報錯
            template<typename T1,typename T2>
            void check_size()
            {
                 
            int dmp[sizeof(T1)==sizeof(T2)];
            }

            比如
            check_size<int,long>();//ok
            check_size<int,char>();//compile error:cannot allocate an array of constant size 0

            2.不同類型的指針需要強制轉換
            以此可以用來判斷兩個對象是否有繼承關系
            template<typename T1,typename T2>
            void is_derived(T1 *pd =0 ,T2 *pb=0)
            {
                pb 
            = pd;
            }
            比如:
            is_derived<int,char>()  //compile failed

            3.union的成員不能是非POD
            union Test
            {
                std::string s; //illegal
            };
            這一點可以用來測試一個類型是否是POD
            template<typename T>
            void check_pod()
            {
                union {
                    T data;
                };
            };
            比如:
            check_pod<int>();//ok
            check_pod<std::string>();//failed


            常用的技巧:

            1.利用模板特化
            Loki里面的例子
            namespace Loki
            {
                template
            <int> struct CompileTimeError;
                template
            <> struct CompileTimeError<true> {};
            }

            #define LOKI_STATIC_CHECK(expr, msg) \
                { Loki::CompileTimeError
            <((expr) != 0)> ERROR_##msg; (void)ERROR_##msg; } 
            利用特化來定制錯誤信息

            2.利用空函數來實現0開銷
            編譯器可能將空函數優化掉

            3.利用enum無開銷的取得編譯期的所得到的整數值
            Loki里面的例子:
            template <class TList> struct Length;
                    template 
            <> struct Length<NullType>
                    {
                        
            enum { value = 0 };
                    };
                    
                    template 
            <class T, class U>
                    
            struct Length< Typelist<T, U> >
                    {
                        
            enum { value = 1 + Length<U>::value };
                    };
            爱做久久久久久| 一本色道久久88综合日韩精品 | 欧美伊人久久大香线蕉综合69 | 久久九九久精品国产免费直播| 色婷婷久久综合中文久久一本| 国产亚洲精久久久久久无码| 久久精品一区二区三区中文字幕| 人妻精品久久无码专区精东影业| 99热精品久久只有精品| 亚洲中文字幕无码久久2020 | 麻豆精品久久精品色综合| 青青草国产97免久久费观看| 九九精品99久久久香蕉| 亚洲国产小视频精品久久久三级| 国产精品久久久久久搜索| 国产69精品久久久久APP下载| 国产AⅤ精品一区二区三区久久| 中文字幕久久波多野结衣av| 综合久久一区二区三区| 国产精品成人无码久久久久久| 国内精品久久久久伊人av| 国产成年无码久久久免费| 人人狠狠综合久久亚洲高清| 中文字幕亚洲综合久久| 国内精品久久九九国产精品| 久久av无码专区亚洲av桃花岛| 中文字幕乱码人妻无码久久 | 精品免费tv久久久久久久| 久久超碰97人人做人人爱| 无码日韩人妻精品久久蜜桃 | 久久影院亚洲一区| 欧美日韩精品久久久久| 久久这里只精品99re66| 亚洲精品99久久久久中文字幕| 亚洲国产成人精品91久久久 | 一本色道久久综合| 亚洲国产视频久久| 无遮挡粉嫩小泬久久久久久久| 亚洲国产精品无码久久一区二区 | 亚洲中文字幕无码久久2017| 日产精品99久久久久久|