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

woaidongmao

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

traits:Traits技術初探

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

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

     void
clone(T* pObj)
     {

         if
(isClonable)
         {

             pObj->clone();
         }

         else

         {

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

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

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

Example 2:
我們再對上面的例子進行一些限制,假設我們的clone操作只涉及基本類型和CComplexObject及其派生類,那么我們可以進一步給出下面的解法:
#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);
}

現在,所有基本類型以及CComplexObject類系都可以用于XContainer.

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

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

評論

# re: traits:Traits技術初探  回復  更多評論   

示例不能運行啊
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>
            国产自产女人91一区在线观看| 亚洲视频每日更新| 亚洲第一网站| 1024国产精品| 国内揄拍国内精品久久| 国产综合久久久久久| 国产一区91| 在线观看视频亚洲| 亚洲免费av电影| 在线视频欧美一区| 欧美在线免费一级片| 免费成人在线视频网站| 欧美激情影音先锋| 亚洲人成77777在线观看网| 国产精品一区免费观看| 国产精品一区二区久久| 国内自拍亚洲| 99在线精品视频在线观看| 中文在线不卡| 麻豆国产精品一区二区三区| 亚洲激情一区| 亚洲欧美日韩一区二区| 久久久久综合一区二区三区| 蜜臀av性久久久久蜜臀aⅴ四虎| 欧美成人一区二区三区在线观看 | 美日韩免费视频| 麻豆免费精品视频| 亚洲美女视频在线免费观看| 午夜亚洲福利在线老司机| 久久视频在线视频| 欧美肉体xxxx裸体137大胆| 国产欧美亚洲一区| 18成人免费观看视频| 亚洲宅男天堂在线观看无病毒| 在线欧美小视频| 在线亚洲一区二区| 免费日韩av| 性视频1819p久久| 久久久久高清| 国产毛片精品视频| 99精品国产一区二区青青牛奶| 伊人婷婷久久| 久久99在线观看| 日韩亚洲视频在线| 欧美高清视频一二三区| 精品1区2区| 久久成人18免费网站| 99精品国产福利在线观看免费| 欧美国产日本| 欧美一区亚洲| 国产欧美日韩精品在线| 99riav久久精品riav| 牛夜精品久久久久久久99黑人| 久久九九精品99国产精品| 亚洲人成网站精品片在线观看| 欧美国产日韩xxxxx| 亚洲欧美自拍偷拍| 国产精品老女人精品视频| 日韩亚洲欧美在线观看| 久久久久一本一区二区青青蜜月| 欧美在线观看视频| 亚洲精品五月天| 欧美激情中文不卡| 亚洲级视频在线观看免费1级| 最近中文字幕日韩精品| 久久亚洲国产精品一区二区| 香港久久久电影| 欧美不卡激情三级在线观看| 久久免费国产精品| 99v久久综合狠狠综合久久| 欧美91精品| 日韩一级黄色av| 99国产精品久久久久久久成人热| 一区二区久久久久| 欧美系列亚洲系列| 午夜精品福利在线| 亚洲免费视频在线观看| 国产视频精品免费播放| 久久夜色精品一区| 久久久久久久网站| 亚洲精品资源| 欧美国产日韩在线| 国产午夜精品视频| 美女视频黄 久久| 国产精品午夜视频| 欧美一级电影久久| 久久久亚洲人| 美女精品在线观看| 免费成人网www| 一区二区三区www| 一区二区不卡在线视频 午夜欧美不卡'| 亚洲高清不卡在线| 久久综合狠狠综合久久综青草| 老色鬼久久亚洲一区二区 | 亚洲欧美国产日韩天堂区| 欧美激情精品久久久久久黑人 | 激情久久久久久久久久久久久久久久| 国产日韩欧美精品综合| 久久国产高清| 久久亚洲影音av资源网| 99热在这里有精品免费| 亚洲自拍偷拍一区| 伊人春色精品| 日韩亚洲欧美在线观看| 国产在线精品二区| 日韩午夜三级在线| 亚洲电影免费在线| 亚洲网友自拍| 亚洲丶国产丶欧美一区二区三区 | 欧美日韩激情小视频| 亚洲欧洲av一区二区| 久久超碰97人人做人人爱| 夜夜爽夜夜爽精品视频| 久久久www成人免费无遮挡大片 | 国产日本欧洲亚洲| 亚洲一区二区三区免费视频| 亚洲国产成人不卡| 亚洲欧美日韩在线不卡| 夜夜躁日日躁狠狠久久88av| 欧美在线视频全部完| 亚洲男人第一av网站| 欧美不卡福利| 欧美波霸影院| 在线电影国产精品| 亚洲日本在线视频观看| 国产精品亚洲综合天堂夜夜| 亚洲一二三四区| 亚洲一区在线直播| 蜜桃av一区二区三区| 久久久久久亚洲精品中文字幕| 91久久久久久| 激情成人在线视频| 欧美亚洲专区| 亚洲欧美三级在线| 欧美婷婷在线| 一区二区高清| 中国日韩欧美久久久久久久久| 亚洲人成网站999久久久综合| 模特精品裸拍一区| 久久只有精品| 精品成人一区| 久久久久久69| 免费亚洲网站| 亚洲国产成人91精品| 在线视频观看日韩| 欧美激情在线免费观看| 国产一区二区三区久久悠悠色av | 亚洲主播在线观看| 一区二区三区 在线观看视| 欧美激情网友自拍| 欧美插天视频在线播放| 在线日韩精品视频| 免费成人美女女| 亚洲日韩欧美视频| 亚洲一区二区三区高清| 欧美亚州一区二区三区| 亚洲性线免费观看视频成熟| 亚洲永久精品国产| 国产亚洲欧洲997久久综合| 久久久中精品2020中文| 欧美大尺度在线| 欧美福利视频在线| 欧美高清视频一区二区三区在线观看 | 亚洲三级免费观看| 欧美日韩精品在线观看| 亚洲欧美久久| 欧美日韩国产一区二区| 一本一本久久a久久精品综合麻豆 一本一本久久a久久精品牛牛影视 | 久久高清一区| 黄色另类av| 欧美精品一区二区三区视频| 亚洲天堂成人在线视频| 国产精品久久久久久五月尺| 欧美一区二区三区在线观看视频| 亚洲一区二区影院| 欧美日韩一区二区高清| 亚洲欧美国产高清| 免费成人av在线| 亚洲午夜一区| 狠狠色狠色综合曰曰| 欧美精品一区二区三区很污很色的| 欧美一区三区二区在线观看| 国产一区二区三区在线观看网站| 亚洲人成网站在线播| 亚洲欧美激情一区二区| 国产精品每日更新| 久久在线视频在线| 亚洲无限乱码一二三四麻| 国产日韩欧美| 欧美xx69| 午夜在线a亚洲v天堂网2018| 欧美国产亚洲视频| 久久久99久久精品女同性| 妖精视频成人观看www| 久久亚洲不卡| 欧美一二三区在线观看| 亚洲精品在线观| 欧美一级网站| 亚洲免费观看| 亚洲国产专区|