• <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 - 28, comments - 179, trackbacks - 0, articles - 1
              C++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            CEnumClass—類型安全的枚舉類型

            Posted on 2008-08-12 10:37 chemz 閱讀(3166) 評(píng)論(3)  編輯 收藏 引用 所屬分類: C++

                                     CEnumClass—類型安全的枚舉類型
                在前面的一篇文章《enum類型的本質(zhì)》中非常詳盡的討論了C++中原生枚舉類型的一些
            本質(zhì)特征(http://www.shnenglu.com/chemz/archive/2007/06/05/25578.html)。在文章的結(jié)
            尾遺留了這樣一個(gè)話題:
                由上面的說(shuō)明枚舉類型有那么多的缺點(diǎn),那我們?cè)鯓硬拍軌蛴幸粋€(gè)類型安全的枚舉類型呢?
            同時(shí)也給出了解決這個(gè)問(wèn)題的一個(gè)思想:
                其實(shí)可以采用類類型來(lái)模擬枚舉類型的有限常量集合的概念,同時(shí)得到類型安全的好處。
                沿著上面所闡述的思想來(lái)看為了解決這個(gè)問(wèn)題必須通過(guò)C++中的類類型來(lái)強(qiáng)化類型的鑒別
            能力,避免出現(xiàn)枚舉類型和默認(rèn)的int的隱示自動(dòng)轉(zhuǎn)換。我們來(lái)看看下面的實(shí)現(xiàn):

            template<typename SubT>
            class CEnumClass
            {
            public:
                friend bool operator==( const SubT &lhs, const SubT &rhs )
                {
                    return lhs.value() == rhs.value();
                }
                friend bool operator!=( const SubT &lhs, const SubT &rhs )
                {
                    return !( lhs == rhs );
                }
                int value() const { return m_value; }

            protected:
                CEnumClass( int i ) : m_value( i ) {}
                CEnumClass( const CEnumClass &rhs ) : m_value( rhs.m_value ) {}
                CEnumClass &operator=( const CEnumClass &rhs ) { m_value = rhs.m_value; return *this; }

            protected:
                int m_value;
            };

                首先簡(jiǎn)單的說(shuō)明一下這個(gè)類,CEnumClass是一個(gè)奇異遞歸模板,也就是說(shuō)模板參數(shù)SubT
            是CEnumClass<SubT>的子類,那么這樣一來(lái)為了聲明一個(gè)枚舉類就必須要想下面這樣:

            EType.hpp

            class EType : public CEnumClass<EType>
            {
            };

            上面聲明就完成了enum EType這樣一個(gè)過(guò)程,但是一個(gè)枚舉類型不僅僅只是有類型,其中還
            包括了有限常量枚舉子,那我們就需要在類聲明中添加對(duì)應(yīng)的枚舉子的定義:

            EType.hpp

            class EType : public CEnumClass<EType>
            {
            public:
                static const EType e1;
                static const EType e2;
                static const EType e3;   
               
            private:
                EType( int i );
            };
            ================================================================================
            EType.cpp

            const EType EType::e1 = 0;
            const EType EType::e2 = 1;
            const EType EType::e3 = 2;

            EType::EType( int i ) : CEnumClass<EType>( i )
            {
            }

            有了上面的定義就完成了一個(gè)枚舉類型的定義了,現(xiàn)在我們來(lái)分析一下這個(gè)類型是否真的能
            夠解決文章《enum類型的本質(zhì)》中所提到的所有缺陷和陷阱,同時(shí)又不失為真正的枚舉含義。

            1. 有限常量集合
               由于EType類的構(gòu)造函數(shù)是私有的,所以無(wú)法在class聲明之外定義任何類的實(shí)例,所以
            所有的類實(shí)例必須在class聲明中定義,有限性得到滿足。常量屬性可以通過(guò)是否能夠修改
            實(shí)例的內(nèi)容來(lái)進(jìn)行判斷,這里沒(méi)有任何辦法可以修改枚舉子e1、e2、e3中的內(nèi)容,因?yàn)樗?br>們本身是const屬性,同時(shí)其成員均是外部不可訪問(wèn)的。

            2. 尺寸大小
               分析一下這個(gè)類就可以很清楚的判斷出sizeof( EType ) == sizeof( int ),尺寸固定
            成為一個(gè)int類型的大小,不再是可以隨著其取值范圍變化的了,同時(shí)也沒(méi)有占用任何額外
            的空間,空間利用率非常高效。

            3. 邊界約束
               如果要定義一個(gè)枚舉類型的變量,就必須像下面這樣子:
            EType val1 = EType::e1;
            EType val2 = EType::e2;
            EType val3 = EType::e3;
            你不可能像下面這樣子:
            EType val1;
            EType val2 = 1;
            EType val2 = 100;
            也就是說(shuō)一個(gè)枚舉變量的初始值必須在集合范圍之內(nèi),不可能越過(guò)這個(gè)范圍,也不可能取隨
            機(jī)值。

            4. 代替int類型
               文章《enum類型的本質(zhì)》中也明確的討論了enum類型不能在任何情況下替代int類型,而
            在這里只要通過(guò)value函數(shù)調(diào)用就可以返回對(duì)應(yīng)的int值,不就可以替代int類型了么。也就
            是像這樣:
            int i = val1.value();
            這種做法是顯示的,你現(xiàn)在知道你自己在干什么,而不是編譯器隱示為你完成的。

                對(duì)于其他剩余的內(nèi)容,比如比較、輸入輸出等大家可以自行練習(xí)完成,這里就不論述了。
               

            Feedback

            # re: CEnumClass—類型安全的枚舉類型  回復(fù)  更多評(píng)論   

            2008-08-13 10:05 by Kevin Lynx
            我覺(jué)得,用你這個(gè)類與普通的enum相比,更多時(shí)候我們需要的是一個(gè)方便的enum,即使它沒(méi)有你這個(gè)class安全;
            如果我沒(méi)弄錯(cuò)的話,你這個(gè)類雖然sizeof為sizeof(int),但這并不是你所說(shuō)的“同時(shí)也沒(méi)有占用任何額外的空間”,因?yàn)檫€有很多static常量。

            # re: CEnumClass—類型安全的枚舉類型  回復(fù)  更多評(píng)論   

            2010-05-12 22:53 by water
            很棒啊,確實(shí)解決的非常徹底。

            # re: CEnumClass—類型安全的枚舉類型  回復(fù)  更多評(píng)論   

            2011-02-22 11:42 by 路人
            這樣并不會(huì)提高程序的效率,反而會(huì)降低,影響程序的可讀性,在枚舉成員后面添加一個(gè)不使用的枚舉值作為強(qiáng)制轉(zhuǎn)化使用,如
            enum TYPE
            {
            TYPE1 = 0,
            TYPE2 = 0,
            TYPE_INT = 0xffffffff, // 作為強(qiáng)制轉(zhuǎn)化int類型使用
            }
            国产精品9999久久久久| 久久久亚洲精品蜜桃臀| 久久精品国产亚洲AV香蕉| 久久狠狠色狠狠色综合| 思思久久99热只有频精品66| 久久er99热精品一区二区| 久久精品无码一区二区日韩AV| 久久无码中文字幕东京热| 国产精品久久久香蕉| 欧美一区二区三区久久综| 久久99国产综合精品| 国产成人精品综合久久久| 成人资源影音先锋久久资源网| 亚洲欧美国产精品专区久久| 97久久精品无码一区二区| 久久精品国产一区二区| 久久婷婷五月综合国产尤物app | 色综合久久精品中文字幕首页| 久久精品18| 久久精品日日躁夜夜躁欧美| 久久精品中文闷骚内射| 国产无套内射久久久国产| 亚洲愉拍99热成人精品热久久 | 亚洲综合精品香蕉久久网| 亚洲伊人久久大香线蕉苏妲己| 久久精品国产99久久久香蕉| 色狠狠久久AV五月综合| 亚洲Av无码国产情品久久| 久久久久国产一级毛片高清版| 久久强奷乱码老熟女网站| 久久中文娱乐网| 日产精品久久久久久久| 国产精品久久久久AV福利动漫| 91精品国产91热久久久久福利| 日韩欧美亚洲综合久久影院Ds| A狠狠久久蜜臀婷色中文网| 久久人人爽人人爽人人片av麻烦| 1000部精品久久久久久久久| 奇米影视7777久久精品| 精品久久久中文字幕人妻| 亚洲欧洲久久久精品|