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

woaidongmao

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

Traits技術(shù)

.概念

Trait的中文意思就是特性,Traits就像特性萃取機(jī),榨取不同類的特性,以便能統(tǒng)一處理。Traits依靠顯式模板特殊化(explicit template specialization)來把代碼中因類型不同而發(fā)生變化的片斷拖出來,用統(tǒng)一的接口來包裝。這個接口可以包含一個C++類所能包含的任何東西:內(nèi)嵌類型,成員函數(shù),成員變量,作為客戶的模板代碼可以通過traits模板類所公開的接口來間接訪問之。花了點(diǎn)時間,憋了一個示例程序,雖然沒什么實(shí)際意義,但對于理解traits來說,可能會有幫助。

#include <iostream>

class CM {};

class CA {};

class CIM {};

template< typename T >

class Traits

{

public:

    typedef unsigned int ValueType;

    Traits() : m_rate( 2 ) {}

    ValueType ComputeValue( ValueType value ) { return value * m_rate; }

private:

    ValueType m_rate;

};

template<>

class Traits< CM >

{

public:

    typedef double ValueType;

    Traits() : m_rate( 1.2 ) {}

    ValueType ComputeValue( ValueType value ) { return value * m_rate; }

private:

    ValueType m_rate;

};

template<>

class Traits< CA >

{

public:

    typedef int ValueType;

    Traits() : m_rate( -1 ) {}

    ValueType ComputeValue( ValueType value ) { return value * m_rate; }

private:

    ValueType m_rate;

};

template< typename T >

struct ValueCount

{

    void result()

    {

        Traits< T > traits;

        Traits< T >::ValueType value = static_cast< Traits< T >::ValueType >( 2 );

        std::cout << traits.ComputeValue( value ) << std::endl;

    }

};

int main()

{

    ValueCount< CIM > cim;

    cim.result();

    ValueCount< CM > cm;

    cm.result();

    ValueCount< CA > ca;

    ca.result();

    return 0;

}

代碼中的Tratis類對于CACM有顯式的特化實(shí)現(xiàn),其中ValueType類型和rate與默認(rèn)的實(shí)現(xiàn)不同,在類ValueCount中,利用Tratis對不同類型用一個統(tǒng)一的接口符號處理。程序的運(yùn)行結(jié)果是42.4-2。(這是我的第一個模版程序J

2.SGI STL中的__type_traits

SGI實(shí)現(xiàn)版的STL中,為了獲取高效率,提供了__type_traits,用來提取類的信息,比如類是否擁有trival的構(gòu)造、析構(gòu)、拷貝、賦值操作,然后跟據(jù)具體的信息,就可提供最有效率的操作。以下摘錄cygwingcc3.3源碼,有改動,在<type_traits.h>中。

struct __true_type {};

struct __false_type {};

template <class _Tp>

struct __type_traits {

    typedef __false_type has_trivial_default_constructor;

    typedef __false_type has_trivial_copy_constructor;

    typedef __false_type has_trivial_assignment_operator;

    typedef __false_type has_trivial_destructor;

    typedef __false_type is_POD_type;

};

對于普通類來講,為了安全起見,都認(rèn)為它們擁有non-trival的構(gòu)造、析構(gòu)、拷貝、賦值函數(shù),POD是指plain old data。接下來對C++的原生類型(boolint double之類)定義了顯式的特化實(shí)現(xiàn),以double為例:

template<> struct __type_traits<long double> {

    typedef __true_type has_trivial_default_constructor;

    typedef __true_type has_trivial_copy_constructor;

    typedef __true_type has_trivial_assignment_operator;

    typedef __true_type has_trivial_destructor;

    typedef __true_type is_POD_type;

};

還有,對所有的原生指針來講,它們的構(gòu)造、析構(gòu)等操作也是trival的,因此有:

template <class _Tp>

struct __type_traits<_Tp*> {

    typedef __true_type has_trivial_default_constructor;

    typedef __true_type has_trivial_copy_constructor;

    typedef __true_type has_trivial_assignment_operator;

    typedef __true_type has_trivial_destructor;

    typedef __true_type is_POD_type;

};

簡化<stl_algobase.h>copy的部分代碼來說明對__type_traits的應(yīng)用。

template<typename _Tp>

inline _Tp*

__copy_trivial(const _Tp* __first, const _Tp* __last, _Tp* __result)

{

    memmove(__result, __first, sizeof(_Tp) * (__last - __first));

    return __result + (__last - __first);

}

template<typename _Tp>

inline _Tp*

__copy_aux (_Tp* __first, _Tp* __last, _Tp* __result, __true_type)

{ return __copy_trivial(__first, __last, __result); }

template<typename _Tp>

inline _Tp*

__copy_aux (_Tp* __first, _Tp* __last, _Tp* __result, __false_type)

{ 另外處理; }

template<typename _InputIter, typename _OutputIter>

inline _OutputIter

copy (_InputIter __first, _InputIter __last, _OutputIter __result)

{

    typedef typename iterator_traits<_InputIter>::value_type _ValueType;

    typedef typename __type_traits<_ValueType>::has_trivial_assignment_operator _Trivial;

    return __copy_aux(__first, __last, __result, _Trivial());

}

Copy函數(shù)利用__type_traits判斷當(dāng)前的value_type是否有trival的賦值操作,如果是,則產(chǎn)生類__true_type的實(shí)例,編譯時選擇__copy_trivial函數(shù)進(jìn)行memmove,效率最高。如果是non-trival的賦值操作,則另作處理,效率自然低些。__true_type__false_type之所以是類,就因?yàn)?span lang="EN-US">C++的函數(shù)重載是根據(jù)類型信息來的,不能依據(jù)參數(shù)值來判別。使用SGI STL時,可以為自己的類定義__type_traits顯式特化版本,以求達(dá)到高效率。

3. STL中的iterator_traits

iterator_traits提供5個特性的提取,至于為什么是5個以及iterator的分類,以后再議。代碼包含在<stl_iterator_base_types.h>中。

template<typename _Category, typename _Tp, typename _Distance = ptrdiff_t,

typename _Pointer = _Tp*, typename _Reference = _Tp&>

struct iterator

{

    typedef _Category iterator_category;

    typedef _Tp value_type;

    typedef _Distance difference_type;

    typedef _Pointer pointer;

    typedef _Reference reference;

};

template<typename _Iterator>

struct iterator_traits {

    typedef typename _Iterator::iterator_category iterator_category;

    typedef typename _Iterator::value_type value_type;

    typedef typename _Iterator::difference_type difference_type;

    typedef typename _Iterator::pointer pointer;

    typedef typename _Iterator::reference reference;

};

原生指針(如int*double*)也是iterator,但它不是類,無法提取出value_type,所以要對原生指針和const原生指針進(jìn)行顯式特化。

template<typename _Tp>

struct iterator_traits<_Tp*> {

    typedef random_access_iterator_tag iterator_category;

    typedef _Tp value_type;

    typedef ptrdiff_t difference_type;

    typedef _Tp* pointer;

    typedef _Tp& reference;

};

template<typename _Tp>

struct iterator_traits<const _Tp*> {

    typedef random_access_iterator_tag iterator_category;

    typedef _Tp value_type;

    typedef ptrdiff_t difference_type;

    typedef const _Tp* pointer;

    typedef const _Tp& reference;

};

現(xiàn)在,對于所有的iterator都可以正確的提取出以上5個特性。

下面解釋iterator_categoryiterator共分為5類,input_iteratoroutput_iteratorforward_iteratorbidirectional_iteratorrandom_access_iterator。其中forward_iteratorinput_iteratoroutput_iterator的強(qiáng)化(refinement),bidirectional_iteratorforward_iterator的強(qiáng)化,random_access_iteratorbidirectional_iterator的強(qiáng)化。由于5iterator的性質(zhì)的同異,需要對它們的種類進(jìn)行區(qū)分,制定特化的函數(shù)以達(dá)到最優(yōu)的效率,就像上一節(jié)的type_traits一樣。需要強(qiáng)調(diào)的是,強(qiáng)化不是繼承,C++重載機(jī)制支持對繼承類的正確選擇。由于不同iterator有共同的操作,在iterator_category中建立繼承關(guān)系可以簡化大部分特化函數(shù)的實(shí)現(xiàn)。

struct input_iterator_tag {};

struct output_iterator_tag {};

struct forward_iterator_tag : public input_iterator_tag {};

struct bidirectional_iterator_tag : public forward_iterator_tag {};

struct random_access_iterator_tag : public bidirectional_iterator_tag {};

iterator_category帶來的效率優(yōu)化,可由在<stl_iterator_base_funcs.h>內(nèi)的兩個函數(shù)看出,一個是用來計算兩個iterator的距離__distance,一個是將iterator累進(jìn)n次的__advance。列舉__distance的代碼如下,有改動。

template<typename _InputIterator>

inline typename iterator_traits<_InputIterator>::difference_type

__distance(_InputIterator __first, _InputIterator __last,

input_iterator_tag)

{

    typename iterator_traits<_InputIterator>::difference_type __n = 0;

    while (__first != __last) {

        ++__first; ++__n;

    }

    return __n;

}

template<typename _RandomAccessIterator>

inline typename iterator_traits<_RandomAccessIterator>::difference_type

__distance(_RandomAccessIterator __first, _RandomAccessIterator __last,

random_access_iterator_tag)

{ return __last - __first; }

template<typename _Iter>

inline typename iterator_traits<_Iter>::iterator_category

__iterator_category(const _Iter&)

{ return typename iterator_traits<_Iter>::iterator_category(); }

template<typename _InputIterator>

inline typename iterator_traits<_InputIterator>::difference_type

distance(_InputIterator __first, _InputIterator __last)

{ return __distance(__first, __last, __iterator_category(__first)); }

4. traits技術(shù)還有很夸張的應(yīng)用。《C++ 設(shè)計新思維:范型編程與設(shè)計模式之應(yīng)用》中有體現(xiàn),或者,泛型編程還得依賴traits技術(shù),也許以后的C++會從語言特性上支持traits

 

posted on 2008-11-08 22:48 肥仔 閱讀(2366) 評論(0)  編輯 收藏 引用 所屬分類: C++ 模板

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产日韩欧美精品| 亚洲精品久久久久| 夜夜躁日日躁狠狠久久88av| 久久午夜色播影院免费高清| 亚洲欧美国产日韩中文字幕| 久久久免费观看视频| 亚洲人成网站999久久久综合| 国产日韩欧美在线视频观看| 久久久久久久久久看片| 久久久夜色精品亚洲| 99视频+国产日韩欧美| 久久精品国产久精国产一老狼 | 欧美影院在线| 亚洲欧洲日产国产综合网| 欧美日本在线| 欧美亚洲成人精品| 精品成人一区二区| 国产精品美女主播在线观看纯欲| 久久久91精品国产一区二区精品| 99re66热这里只有精品3直播| 一本色道久久加勒比88综合| 欧美成人精品三级在线观看| 亚洲欧美一区二区原创| 91久久精品一区二区三区| 国产精品美女午夜av| 国产欧美日韩一区二区三区在线观看 | 午夜精品福利视频| 加勒比av一区二区| 国产精品免费一区豆花| 精品96久久久久久中文字幕无| 国产精品五区| 欧美日韩三级一区二区| 国产亚洲欧美日韩在线一区| 一区二区三区 在线观看视| 久久一区二区三区超碰国产精品| 亚洲乱码国产乱码精品精| 久久久av毛片精品| 午夜一区二区三区不卡视频| 亚洲伦理自拍| 亚洲激情视频网| 99精品视频一区| 亚洲黄色在线| 久久久久久一区二区| 国产日韩欧美一区二区| 国产精品av免费在线观看| 亚洲国产精品小视频| 久久影音先锋| 午夜亚洲伦理| 亚洲午夜av电影| 免费成人性网站| 久久夜色精品国产噜噜av| 欧美日韩不卡| 亚洲美女尤物影院| 亚洲伦理精品| 亚洲国产日本| 久久夜色精品国产噜噜av| 亚洲一区二区在线视频| 欧美综合国产| 裸体素人女欧美日韩| 国产亚洲成精品久久| 亚洲欧美视频在线| 亚洲女性喷水在线观看一区| 欧美伊人久久大香线蕉综合69| 欧美激情一区二区三区四区| 欧美高清在线精品一区| 在线看片日韩| 亚洲第一成人在线| 这里只有精品丝袜| 国产精品白丝jk黑袜喷水| 欧美日韩在线视频一区| 在线综合亚洲| 亚洲特黄一级片| 性欧美办公室18xxxxhd| 麻豆成人综合网| 欧美日韩国产丝袜另类| 国产精品国产一区二区| 激情欧美丁香| 欧美成人免费全部| 一个人看的www久久| 国产精品久久久亚洲一区| 午夜精品久久99蜜桃的功能介绍| 亚洲素人一区二区| 久久成人精品一区二区三区| 欧美一级久久| 国产精品99久久久久久有的能看| 亚洲精品乱码久久久久久久久 | 一区二区三区在线观看视频| 欧美阿v一级看视频| 欧美精品电影| 国产精品三区www17con| 亚洲欧洲一级| 亚洲欧美日韩一区在线| 久久久91精品| 亚洲午夜国产一区99re久久| 久久久亚洲国产天美传媒修理工| 亚洲激情电影中文字幕| 久久成人精品| 欧美sm视频| 亚洲欧美国内爽妇网| 亚洲第一成人在线| 一区二区亚洲精品国产| 欧美成人69| 香蕉尹人综合在线观看| 亚洲日本电影在线| 性欧美1819性猛交| 国产精品九九| 久久久久久亚洲综合影院红桃| 久久综合99re88久久爱| 亚洲在线视频观看| 亚洲最新视频在线播放| 欧美风情在线观看| 亚洲第一区中文99精品| 久久国产精品99国产精| 浪潮色综合久久天堂| 午夜精品成人在线| 在线亚洲美日韩| 欧美精品在线观看91| 欧美在线观看视频| 欧美日韩大片一区二区三区| 亚洲综合三区| 欧美经典一区二区| 欧美激情成人在线| 黄色亚洲网站| 欧美一区二区三区免费视频| 亚洲一区精品视频| 欧美久久影院| 亚洲日本黄色| 日韩性生活视频| 欧美二区不卡| 亚洲电影免费观看高清完整版在线 | 蜜臀a∨国产成人精品| 国产目拍亚洲精品99久久精品| 日韩一级裸体免费视频| 欧美大胆a视频| 99在线精品观看| 欧美成人国产va精品日本一级| 麻豆精品网站| 好吊一区二区三区| 美国十次了思思久久精品导航| 国产精品久久久一区二区三区| 最近中文字幕mv在线一区二区三区四区 | 亚洲剧情一区二区| 欧美成人精品一区| 欧美大片18| 欧美日韩在线另类| 亚洲精品欧美激情| 一区二区三区国产精品| 欧美精选在线| 欧美在线观看视频一区二区三区| 午夜视频一区在线观看| 欧美中文日韩| 狠狠操狠狠色综合网| 亚洲第一黄网| 欧美日韩综合| 一区二区高清在线观看| 狠狠色噜噜狠狠色综合久| 香蕉av777xxx色综合一区| 亚洲精品免费看| 亚洲一区激情| 久热精品在线| 一区二区精品在线观看| 亚洲欧美另类中文字幕| 欧美亚洲三区| 黄色小说综合网站| 亚洲综合另类| 一区二区三区高清在线观看| 黑人一区二区| 欧美另类极品videosbest最新版本| 亚洲精品视频在线观看网站| 性伦欧美刺激片在线观看| 一区久久精品| 中日韩男男gay无套| 欧美一区在线视频| 欧美日韩国产综合网 | 亚洲免费黄色| 久久精品一区四区| 亚洲国产片色| 久久久久综合网| 一区二区久久久久| 男女精品视频| 久久精品女人的天堂av| 欧美精品一区二区三区高清aⅴ| 99日韩精品| 亚洲一区在线免费观看| 国模精品一区二区三区| 欧美激情2020午夜免费观看| 欧美激情视频给我| 欧美一区1区三区3区公司| 亚洲精品一二三| 一区二区在线免费观看| 国产精品久久激情| 欧美精品一线| 免费亚洲一区二区| 久久国产一区二区| 亚洲人在线视频| 欧美高清在线视频观看不卡| 篠田优中文在线播放第一区| 亚洲美洲欧洲综合国产一区| 欧美国产一区二区在线观看| 久久久久久久综合日本|