青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

woaidongmao

文章均收錄自他人博客,但不喜標(biāo)題前加-[轉(zhuǎn)貼],因其丑陋,見諒!~
隨筆 - 1469, 文章 - 0, 評論 - 661, 引用 - 0
數(shù)據(jù)加載中……

traits:Traits技術(shù)初探

概述:
traits
是一種特性萃取技術(shù),它在Generic Programming中被廣泛運(yùn)用,常常被用于使不同的類型可以用于相同的操作,或者針對不同類型提供不同的實現(xiàn).traits在實現(xiàn)過程中往往需要用到以下三種C++的基本特性:
enum
typedef
template
(partial) specialization
其中:
enum
用于將在不同類型間變化的標(biāo)示統(tǒng)一成一個,它在C++中常常被用于在類中替代define,你可以稱enum為類中的define;
typedef
則用于定義你的模板類支持特性的形式,你的模板類必須以某種形式支持某一特性,否則類型萃取器traits將無法正常工作.看到這里你可能會想,太苛刻了吧?其實不然,不支持某種特性本身也是一種支持的方式(見示例2,我們定義了兩種標(biāo)示,__xtrue_type__xfalse_type,分別表示對某特性支持和不支持).
template
(partial) specialization被用于提供針對特定類型的正確的或更合適的版本.
借助以上幾種簡單技術(shù),我們可以利用traits提取類中定義的特性,并根據(jù)不同的特性提供不同的實現(xiàn).你可以將從特性的定義到萃取,再到traits的實際使用統(tǒng)稱為traits技術(shù),但這種定義使得traits顯得過于復(fù)雜,我更愿意將traits的定義限于特性萃取,因為這種定義使得traits顯得更簡單,更易于理解,^_^.

舉例:
上面提到過,traits可被用于針對不同類型提供不同的實現(xiàn),那么下面就舉兩個例子來說明如何實現(xiàn)這一點(diǎn).
Example 1:
假定我們需要為某個類設(shè)計一個可以對所有類型(包括普通的int/long...,提供了clone方法的復(fù)雜類型CComplexObject,及由該類派生的類)進(jìn)行操作的函數(shù)clone,下面,先用OO的方法來考慮一下解決方案.看到前面的條件,最先跳進(jìn)你腦子里的肯定是Interface,pure virtual function等等.對于我們自己設(shè)計的類CComplexObject而言,這不是問題,但是,對于基本數(shù)據(jù)類型呢?還有那些沒有提供clone方法的復(fù)雜類型呢?(這時候你可能會想,要是Java該多easy,所有類都默認(rèn)從Object派生,Object已提供了一個默認(rèn)的clone方法,但是,要使類真正支持clone,還必須implements Cloneable,所以,同樣也不能避免這里遇到的麻煩).
下面是一個可能的解決方案:
template
<typename T, bool isClonable>
class
XContainer
{
     ...

     void
clone(T* pObj)
     {

         if
(isClonable)
         {

             pObj->clone();
         }

         else

         {

             //... non-Clonable algorithm ...
         }
     }
};

但是只要你測試一下,這段代碼不能通過編譯.為什么會這樣呢?原因很簡單:對于沒有實現(xiàn)clone方法的非Clonable類或基本類型,pObj->clone這一句是非法的.
那么怎樣解決上面的這個難題呢?上面不能通過編譯的代碼告訴我們,要使我們的代碼通過編譯,就不能使非Clonable類或基本類型的代碼中出現(xiàn)pObj->clone,即我們需要針對不同類型提供不同的實現(xiàn).為了實現(xiàn)這一點(diǎn),我們可以在我們的模板類中用enum定義一個trait,以標(biāo)示類是否為Clonable,然后在原模板類內(nèi)部引入一個traits提取類Traits,通過對該類進(jìn)行specilizing,以根據(jù)不同的trait提供不同的實現(xiàn).具體實現(xiàn)如下:
#include <iostream>
using namespace std;

class
CComplexObject // a demo class
{
public
:
     void
clone() { cout << "in clone" << endl; }
};


// Solving the problem of choosing method to call by inner traits class
template <typename T, bool isClonable>
class
XContainer
{

public
:
     enum
{Clonable = isClonable};

     void
clone(T* pObj)
     {

         Traits<isClonable>().clone(pObj);
     }


     template
<bool flag>
         class
Traits
     {
     };


     template
<>
         class
Traits<true>
     {

     public
:
         void
clone(T* pObj)
         {

             cout << "before cloning Clonable type" << endl;
             pObj->clone();
             cout << "after cloning Clonable type" << endl;
         }
     };


     template
<>
         class
Traits<false>
     {

     public
:
         void
clone(T* pObj)
         {

             cout << "cloning non Clonable type" << endl;
         }
     };
};


void
main()
{

     int
* p1 = 0;
     CComplexObject* p2 = 0;

     XContainer<int, false> n1;
     XContainer<CComplexObject, true> n2;

     n1.clone(p1);
     n2.clone(p2);
}

編譯運(yùn)行一下,上面的程序輸出如下的結(jié)果:
doing something non Clonable
before doing something Clonable
in clone
after doing something Clonable
這說明,我們成功地根據(jù)傳入的isClonable模板參數(shù)為模板實例選擇了不同的操作,在保證接口相同的情況下,為不同類型提供了不同的實現(xiàn).

Example 2:
我們再對上面的例子進(jìn)行一些限制,假設(shè)我們的clone操作只涉及基本類型和CComplexObject及其派生類,那么我們可以進(jìn)一步給出下面的解法:
#include <iostream>
using namespace std;

struct
__xtrue_type { }; // define two mark-type
struct __xfalse_type { };

class
CComplexObject // a demo class
{
public
:
     virtual
void clone() { cout << "in clone" << endl; }
};


class
CDerivedComplexObject : public CComplexObject // a demo derived class
{
public
:
     virtual
void clone() { cout << "in derived clone" << endl; }
};


// A general edtion of Traits
template <typename T>
struct
Traits
{

     typedef
__xfalse_type has_clone_method; // trait 1: has clone method or not? All types defaultly has no clone method.
};

// Specialized edtion for ComplexObject
template <>
struct
Traits<CComplexObject>
{

     typedef
__xtrue_type has_clone_method;
};


template
<typename T>
class
XContainer
{

     template
<typename flag>
         class
Impl
     {
     };

     template
<>
         class
Impl <__xtrue_type>
     {

     public
:
         void
clone(T* pObj)
         {

             pObj->clone();
         }
     };

     template
<>
         class
Impl <__xfalse_type>
     {

     public
:
         void
clone(T* pObj)
         {
         }
     };

public
:
     void
clone(T* pObj)
     {

         Impl<Traits<T>::has_clone_method>().clone(pObj);
     }
};


void
main()
{

     int
* p1 = 0;
     CComplexObject c2;
     CComplexObject* p2 = &c2;
     CDerivedComplexObject c3;
     CComplexObject* p3 = &c3; // you must point to a derived object by a base-class pointer,
                             //it's a little problem

     XContainer<int> n1;
     XContainer<CComplexObject> n2;
     XContainer<CComplexObject> n3;

     n1.clone(p1);
     n2.clone(p2);
     n3.clone(p3);
}

現(xiàn)在,所有基本類型以及CComplexObject類系都可以用于XContainer.

結(jié)語:
看到這里,你或許會說,traits不過如此,還以為是什么高深的玩意呢!其實技術(shù)就是這樣,說白了都很Easy,關(guān)鍵是怎么將他們用于實際,為實際的Designing/Development服務(wù).畢竟,IT領(lǐng)域,不能應(yīng)用于實際的技術(shù)是沒有價值的.

posted on 2008-11-09 01:19 肥仔 閱讀(7933) 評論(1)  編輯 收藏 引用 所屬分類: C++ 模板

評論

# re: traits:Traits技術(shù)初探  回復(fù)  更多評論   

示例不能運(yùn)行啊
2016-04-26 11:31 | lzq
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产视频欧美视频| 久久国产免费| 久久久亚洲欧洲日产国码αv | 亚洲视频精选| 久久视频精品在线| 亚洲国产黄色片| 亚洲成色精品| 欧美在线播放高清精品| 午夜免费在线观看精品视频| 午夜影视日本亚洲欧洲精品| 亚洲人在线视频| 欧美色视频日本高清在线观看| 亚洲视频axxx| 欧美一区二区三区电影在线观看| 亚洲国产精品尤物yw在线观看 | 一本久道久久综合中文字幕| 亚洲视频免费在线观看| 一区二区在线观看av| 欧美日韩日韩| 久久精品99无色码中文字幕| 麻豆精品在线视频| 欧美日韩色一区| 欧美ed2k| 国产精品丝袜xxxxxxx| 欧美—级a级欧美特级ar全黄| 亚洲欧美日本视频在线观看| 久久久久亚洲综合| 国产精品h在线观看| 亚洲第一综合天堂另类专| 国产一区99| 亚洲精品一区二区三区樱花| 尤物九九久久国产精品的特点| 亚洲大胆av| 欧美中文字幕在线视频| 欧美在线三级| 亚洲视频一二三| 久久网站热最新地址| 日韩一级黄色大片| 亚洲激情国产| 性做久久久久久| 欧美一区二区黄| 欧美99在线视频观看| 亚洲免费成人| 亚洲日本中文| 欧美在线地址| 久久午夜精品| 国产欧美一区二区白浆黑人| 国产精品视频自拍| 一本色道久久综合亚洲二区三区| 老司机午夜精品视频| 亚洲一区尤物| 国产精品亚发布| 国产亚洲aⅴaaaaaa毛片| 国产精品入口麻豆原神| 国产精品久久国产三级国电话系列| 欧美劲爆第一页| 在线观看精品一区| 亚洲精品网址在线观看| 亚洲美女毛片| 欧美激情欧美激情在线五月| 久久久久久亚洲精品杨幂换脸| 国产一区二区中文字幕免费看| 午夜一区二区三视频在线观看| 久久九九99| 免费欧美在线| 久久伊人免费视频| 欧美日韩国产小视频| 日韩西西人体444www| 亚洲国产欧美日韩精品| 亚洲视频一二区| 久久av一区二区三区亚洲| 久色成人在线| 亚洲高清中文字幕| 亚洲一区二区三区四区在线观看| 亚洲精品综合| 国产精品国产| 亚洲国产mv| 欧美激情2020午夜免费观看| 亚洲一区二区三区精品动漫| 国产美女诱惑一区二区| 久久尤物视频| 这里是久久伊人| 国产午夜精品麻豆| 欧美a级片网| 欧美一区影院| 欧美日韩一卡二卡| 亚洲欧美在线磁力| 久久精品国产精品亚洲精品| 欧美日韩三区| 亚洲国产黄色| 日韩视频免费观看高清完整版| 久久久999| 99亚洲视频| 欧美不卡高清| 亚洲自啪免费| 亚洲国产成人久久| 在线亚洲一区二区| 在线播放豆国产99亚洲| 久久精品盗摄| 欧美国产高潮xxxx1819| 欧美激情区在线播放| av成人天堂| 欧美在线一区二区| 一区二区激情| 亚洲精品1区2区| 国产精品永久免费观看| 亚洲一区二区三区四区五区午夜| 性刺激综合网| 亚洲男人的天堂在线| 99精品视频一区| 在线精品视频一区二区| 午夜国产精品视频| 国产精品99久久久久久久vr| 日韩一本二本av| 欧美日韩卡一卡二| 中文av字幕一区| 免费观看久久久4p| 亚洲精品视频一区| 久久青青草原一区二区| 亚洲二区在线视频| 午夜亚洲视频| 午夜亚洲伦理| 欧美亚洲视频在线看网址| 国产精品揄拍500视频| 91久久中文| 国产精品毛片a∨一区二区三区|国 | 欧美亚洲视频在线观看| 一本一本久久a久久精品牛牛影视| 久久婷婷国产综合尤物精品| 性欧美videos另类喷潮| 亚洲色图在线视频| 欧美激情视频一区二区三区在线播放| 麻豆av一区二区三区久久| 国产一区二区看久久| 午夜精品久久久久久| 久久福利影视| 国产香蕉97碰碰久久人人| 久久一日本道色综合久久| 国产精品色婷婷| 另类专区欧美制服同性| 国产一区二区日韩精品欧美精品| 亚洲午夜一区二区| 久久精品盗摄| 欧美国产一区二区三区激情无套| 免费一级欧美片在线观看| 欧美日本一区| 亚洲欧洲日韩在线| 亚洲一区二区三区乱码aⅴ| 午夜久久99| 亚洲日本欧美日韩高观看| 夜夜躁日日躁狠狠久久88av| 国产无一区二区| 久久国产乱子精品免费女| 久热精品视频在线观看| 亚洲第一精品福利| 欧美激情免费观看| 久久免费国产精品| 在线观看日韩一区| 午夜宅男欧美| 日韩视频永久免费观看| 欧美3dxxxxhd| 久热国产精品| 亚洲免费观看| 久久国产99| 亚洲三级视频在线观看| 亚洲免费在线视频一区 二区| 久久久女女女女999久久| 欧美黄色精品| 亚洲第一福利社区| 亚洲欧美国产va在线影院| 日韩视频免费| 国产欧美精品日韩精品| 亚洲久久在线| 久久久久久一区| 欧美大成色www永久网站婷| 午夜精彩国产免费不卡不顿大片| 国产一级揄自揄精品视频| 欧美激情一区二区三区全黄| 蜜臀99久久精品久久久久久软件 | 久久国产一区二区| 91久久夜色精品国产九色| 国产精品视频xxx| 欧美波霸影院| 欧美黄色一区二区| 亚洲小视频在线观看| 狠狠狠色丁香婷婷综合激情| 亚洲午夜久久久久久久久电影院| 久久久国产精品亚洲一区| 亚洲在线一区二区三区| 欧美系列精品| 中国成人在线视频| 免费久久99精品国产自| 亚洲五月婷婷| 国产精品www994| 免费日韩成人| 久久中文在线| 久久久久久久综合日本| 每日更新成人在线视频| 亚洲一区一卡| 亚洲视频在线二区|