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

posts - 23,  comments - 94,  trackbacks - 0
/************************************************************************/
/* Copyright (c) 2009, Roc King
All rights reserved.

Redistribution and use in source and binary forms,
    with or without modification, are permitted
    provided that the following conditions are met:

1. Redistributions of source code must retain the above copyright notice,
    this list of conditions and the following disclaimer.

2. Redistributions in binary form must reproduce the above copyright notice,
    this list of conditions and the following disclaimer in the documentation
    and other materials provided with the distribution.

3. Neither the name of the Tju nor the names of its contributors
    may be used to endorse or promote products derived from this software
    without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS
    AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
    INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
    AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
    IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
    INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
    (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
    LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
    HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
    WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
    (INCLUDING NEGLIGENCE OR OTHERWISE)
    ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
    EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.                                                                     
*/
/************************************************************************/


/**
這份代碼詳細(xì)介紹了使用SFINAE技術(shù)實(shí)現(xiàn)is_not_buildin_type的原理。
按順序由上往下閱讀即可。
*/

#include 
<stdio.h>
#include 
<iostream>


/** ------------------------------------------------------------------------ */
#define DEFINITION(prefix)          \
prefix none {};                     \
prefix data { 
int i; };             \
prefix function { 
void f(int ) {} };    \
prefix both { 
int i; double f() { return 0.0; } };

namespace structures { DEFINITION(struct) }
namespace s = structures;

namespace classes { DEFINITION(class) }
namespace c = classes;

namespace unions { DEFINITION(union) }
namespace u = unions;

#undef DEFINITION

/**
上面對(duì)class、struct、union分別定義了:
none        有數(shù)據(jù)成員,無成員函數(shù)
data        有數(shù)據(jù)成員,沒成員函數(shù)
function    無數(shù)據(jù)成員,有成員函數(shù)
both        有數(shù)據(jù)成員,有成員函數(shù)
*/

/** ------------------------------------------------------------------------ */

void test_pointer_to_data_member() {

    
// 一旦某個(gè)類型不是基本數(shù)據(jù)類型,就可以定義成員指針(數(shù)據(jù)成員指針,成員函數(shù)指針)。
    
// 即使它沒有數(shù)據(jù)成員或者成員函數(shù)。

    
// s::none 并沒有數(shù)據(jù)成員或者成員函數(shù)。
    int s::none::* p; //但是可以定義一個(gè)指向s的數(shù)據(jù)成員指針,只要類型不是void
    
// void s::none::* p2; //error C2182: 'p2' : illegal use of type 'void'

    
// 同時(shí),在C++中,字面值0可以隱式轉(zhuǎn)換到任何指針類型。
    p = 0// ok
    double s::none::* p3 = 0// ok

    
// 但是,如果某類型沒有對(duì)應(yīng)類型的數(shù)據(jù)成員,就不能用數(shù)據(jù)成員指針去指向它。
    int s::data::* p4 = 0;
    p4 
= &s::data::i;  // ok
    double s::data::* p5 = 0;
    
// p5 = &s::data::i;
    
// error C2440: '=' : cannot convert from 'int structures::data::* ' to 'double structures::data::* '

    (
void)p3; (void)p5;
}

// 這個(gè)是比較完整的測試
void test_pointer_to_data_member_integrate();


/** ------------------------------------------------------------------------ */

void test_pointer_to_member_function() {
    
// 同理,一旦某個(gè)類型不是基本類型,就可以定義指向該類型的成員函數(shù)的指針。
    
// 并且字面值0可以隱式轉(zhuǎn)換到該指針。

    
int (u::none::* p1)(void)  = 0;
    
double (u::none::* p2)(double= 0;

    
// 如果該類型確實(shí)有匹配的成員函數(shù),可以使用該成員函數(shù)給指針賦值。
    double (u::both::* p3 )(void= &u::both::f;
    
void (u::function::* p4)(int= &u::function::f;

    
// 否則不能賦值
    
// double (u::both::* p5 )(void) = &u::function::f;
    
//error C2440: 'initializing' : cannot convert from 'void (__thiscall unions::function::* )(int)' to 'double (__thiscall unions::both::* )(void)'
    
// void (u::function::* p6)(int) = &u::both::f;
    
//error C2440: 'initializing' : cannot convert from 'double (__thiscall unions::both::* )(void)' to 'void (__thiscall unions::function::* )(int)'

    (
void)p1; (void)p2; (void)p3; (void)p4;
}

// 這個(gè)是比較完整的測試
void test_pointer_to_member_function_integrate();

/** ------------------------------------------------------------------------ */
/**
那么,測試一個(gè)類型是否是內(nèi)建類型的“一個(gè)”方法就是
*/

namespace SFINAE {

    
class true_type { char dummy; true_type(); };
    
class false_type { char dummy[2]; false_type(); };
    
// sizeof(true_type)!=sizeof(false_type)

    template
<class C>
    true_type is_not_buildin_type_test(
int C::* pointer_to_data_member);

    template
<typename T>
    false_type is_not_buildin_type_test();

    
void test_theory() {
        
using namespace std;

        
/* 在當(dāng)前名字空間下, is_not_buildin_type_test是2個(gè)函數(shù)模板的名字:
        template<class C>
        true_type is_not_buildin_type_test(int C::* pointer_to_data_member);
        (以下簡稱模板1)

        template<typename T>
        false_type is_not_buildin_type_test();
        (以下簡稱模板2)

        它們相互構(gòu)成重載。
        
*/

        cout
<<sizeof( is_not_buildin_type_test<c::none>(0) )<<endl;
        
// 0 可以隱式轉(zhuǎn)化成 int c::none::* ,可以匹配模板1 (with C = c::none)

        
// 這里int是無關(guān)緊要的, 只要不是void就行
        
// 當(dāng)然使用其他類型的數(shù)據(jù)成員指針 T C::* (T!=void)
        
// 或者成員函數(shù)指針進(jìn)行測試 T (C::*)(paramter_list),也是可以的
        
// 只是int C::* 寫起來比較方便。

        
// 因?yàn)?) 可以匹配任何類型的對(duì)象,
        
// 所以 0 也可以匹配模板2

        
// 又因?yàn)?)處于重載選擇優(yōu)先級(jí)中的最底層,所以最終匹配模板1。
        
// 注意,此處模板2不能使用(int),或者(T*)因?yàn)樗膬?yōu)先級(jí)高于(int C::*)


        cout
<<sizeof( is_not_buildin_type_test<double>(0) )<<endl;
        
// 0 不能隱式轉(zhuǎn)換成 int double::*,也就不能匹配模板1 ( with C=double )

        
// 但是還有一個(gè)“補(bǔ)救”的函數(shù)模板2,可以匹配任何類型的對(duì)象。
        
// 又因?yàn)镾FINAE(Substitution failure is not an error)機(jī)制
        
// 所以對(duì)模板1的失敗的匹配并不報(bào)錯(cuò)。
    }

    
// 還有一些細(xì)節(jié)
    
// 比如is_not_buildin_type_test并沒有實(shí)現(xiàn)。
    
// 但是因?yàn)樗瑫r(shí)也沒有被調(diào)用, 而僅僅是用sizeof測試它的返回值,所以不算錯(cuò)誤。
    
// 也防止了客戶無意調(diào)用這個(gè)函數(shù)。

    
// 如何得知哪個(gè)is_not_buildin_type_test被重載選中?
    
// 是通過返回值的大小不同來區(qū)分的。

    
// 所以就需要true_type和false_type這2個(gè)東西。
    
// 其實(shí)更合理的命名應(yīng)該是small_type和big_type。
    
// 同時(shí),它們聲明有私有的構(gòu)造函數(shù),并且不實(shí)現(xiàn),防止客戶使用這2個(gè)類。

    
// 還因?yàn)閕s_not_buildin_type_test并沒有真正實(shí)現(xiàn)
    
// 也就沒有真正返回true_type或者false_type
    
// 所以沒有實(shí)現(xiàn)true_type和false_type的構(gòu)造函數(shù)也沒關(guān)系。

    
// 一切都因?yàn)閟izeof ……

    
/** -------------------------------------------------------------------- */
    
/**
    將這種方法再包裝一下
    (避免客戶去使用sizeof( xxx ) == sizeof( ture_type )等等)
    就得到
    
*/

    template
<typename T>
    
class is_not_buildin_type {
        is_not_buildin_type();
    
public:
        
enum { value =
            
sizeof(true_type)==sizeof( is_not_buildin_type_test<T>(0) ) };
    };
    
// 或者將true_type,false_type,定義為它的內(nèi)嵌類型。
    
// 同時(shí)將is_not_buildin_type_test定義為它的靜態(tài)成員函數(shù)。

    template
<typename T>
    
class is_not_buildin_type2 {
        is_not_buildin_type2();

        
// 因?yàn)槭莾?nèi)嵌的private,客戶不能訪問
        
// 所以可以隨意一點(diǎn)
        typedef char small_t;
        
struct big_t { small_t dummy[2]; };

        template
<typename U>
        
static big_t test(void (U::*)(shortfloat) );
        
// 只要是成員指針就ok,無論是數(shù)據(jù)成員指針還是成員函數(shù)指針。
        
// 也無論類型,簽名如何。

        template
<typename U>
        
static small_t test();
        
// 注意補(bǔ)救函數(shù)現(xiàn)在返回small_t

    
public:
        
// 但這也是無關(guān)緊要的,因?yàn)閟mall_t和big_t只是告之哪個(gè)重載被選中的方式。
        
// 只要這里處理好對(duì)應(yīng)就可以了。
        enum { value= sizeof(big_t)==sizeof( test<T>(0) ) };
    };

    
void test_wrapper() {
        
using namespace std;
        cout
<<is_not_buildin_type<c::data>::value<<endl;
        cout
<<is_not_buildin_type<u::both>::value<<endl;
        cout
<<is_not_buildin_type<float>::value<<endl;

        cout
<<is_not_buildin_type2<c::data>::value<<endl;
        cout
<<is_not_buildin_type2<u::both>::value<<endl;
        cout
<<is_not_buildin_type2<float>::value<<endl;
    }

    
// 一個(gè)更完整的測試
    void test_wrapper_integrate();
}

/** ------------------------------------------------------------------------ */
/**測試一個(gè)類型是否是內(nèi)建類型的另一個(gè)方法,需要更少的技巧。*/

namespace partial_specialization {

    template
<typename T>
    
struct is_not_buildin_type { enum { value=true }; };
    
// T不是一個(gè)內(nèi)建類型

    
// 除非
    template<>
    
struct is_not_buildin_type<int> { enum { value=false}; };
    
// T是int
    template<>
    
struct is_not_buildin_type<unsigned int> { enum { value=false}; };
    
// T是unsigned int
    
// .. more ..
}

int main()
{
    
using namespace std;
    test_pointer_to_data_member();
    test_pointer_to_data_member_integrate();
    test_pointer_to_member_function();
    test_pointer_to_member_function_integrate();

    cout
<<endl;
    SFINAE::test_theory();
    cout
<<endl;
    SFINAE::test_wrapper();
    cout
<<endl;
    SFINAE::test_wrapper_integrate();
}



void test_pointer_to_data_member_integrate() {
    
// to do
}
void test_pointer_to_member_function_integrate() {
    
// to do
}

namespace SFINAE {
    
void test_wrapper_integrate() {
        
// to do
    }
}

這個(gè)代碼已經(jīng)能很完美的解釋了~
今天看了C++ Templates 的15章.. 收獲頗多.. 以前的很多疑惑都比較開朗了~

posted on 2009-03-16 23:32 Charlie 侯杰 閱讀(2676) 評(píng)論(3)  編輯 收藏 引用

只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


by Charlie
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲婷婷综合色高清在线| 午夜在线a亚洲v天堂网2018| 免费久久99精品国产自| 久久只精品国产| 91久久综合| 日韩视频在线观看一区二区| 欧美日本在线播放| 亚洲影音先锋| 狠狠色狠狠色综合日日91app| 久久久女女女女999久久| 久久久夜色精品亚洲| 亚洲三级免费| 一本到高清视频免费精品| 国产欧美精品在线| 久久夜色精品亚洲噜噜国产mv| 美女国内精品自产拍在线播放| 日韩亚洲精品电影| 亚洲欧美日韩国产中文 | 国产精品99久久久久久久久久久久| 欧美性一区二区| 久久在线视频在线| 欧美日韩第一页| 久久久久国色av免费观看性色| 欧美xx69| 久久国产精品网站| 欧美日韩123| 在线亚洲免费视频| 久久中文精品| 午夜一区不卡| 免费的成人av| 久久久亚洲精品一区二区三区 | 欧美影院午夜播放| 99国内精品久久| 久久午夜视频| 欧美在线视频观看| 欧美视频一区二区三区四区| 免费欧美在线视频| 国产欧美日韩精品丝袜高跟鞋| 亚洲国产精品视频| 国产精品伦理| 亚洲精选久久| 亚洲人精品午夜在线观看| 欧美在线亚洲在线| 先锋影音网一区二区| 欧美日韩综合在线免费观看| 欧美激情精品久久久久久大尺度 | 国产精品日韩精品欧美在线| 亚洲精品乱码久久久久久黑人| 激情久久久久久| 欧美一区二区三区男人的天堂 | 狠狠久久亚洲欧美| 欧美一区91| 久久精选视频| 国产午夜精品视频| 亚洲免费影视| 欧美一区二区日韩| 国产精品毛片| 亚洲性视频h| 欧美一区不卡| 国产精品亚洲一区| 欧美一区二区精美| 久久视频在线免费观看| 国产一区二区三区在线观看视频| 午夜精品视频| 久久久爽爽爽美女图片| 国产一区香蕉久久| 久久久久国产精品午夜一区| 久久亚洲捆绑美女| 在线观看欧美亚洲| 麻豆av一区二区三区| 亚洲国产欧美另类丝袜| 夜夜爽99久久国产综合精品女不卡| 欧美激情乱人伦| 洋洋av久久久久久久一区| 亚洲一区二区三区高清| 国产精品免费小视频| 欧美在线黄色| 欧美电影在线观看完整版| 亚洲美女中出| 国产精品推荐精品| 久久久久国产精品厨房| 最新国产精品拍自在线播放| 中文欧美字幕免费| 国产亚洲欧洲997久久综合| 久久嫩草精品久久久精品一| 亚洲国产精品高清久久久| 国产精品99久久久久久宅男| 国产精品午夜国产小视频| 久久精品夜色噜噜亚洲a∨ | 欧美日韩国产成人精品| 一区二区日韩免费看| 久久av红桃一区二区小说| 在线播放不卡| 欧美日韩另类字幕中文| 亚洲欧美一区二区三区久久| 欧美v日韩v国产v| 亚洲特级毛片| 在线观看亚洲一区| 欧美日韩视频在线第一区| 欧美一区精品| 亚洲精品欧美一区二区三区| 欧美有码在线视频| 日韩亚洲精品电影| 今天的高清视频免费播放成人 | 亚洲国产另类久久久精品极度| 久久国产精品一区二区| 日韩视频中文字幕| 国产午夜精品久久久| 欧美日韩视频不卡| 久久久久久穴| 午夜亚洲激情| 99re热精品| 欧美激情按摩在线| 久久久久久久性| 性做久久久久久久免费看| 亚洲另类一区二区| 亚洲大黄网站| 国产日韩视频| 国产精品三级视频| 欧美日韩在线另类| 欧美99在线视频观看| 久久九九电影| 亚洲欧美精品伊人久久| 亚洲精品日韩在线观看| 欧美夫妇交换俱乐部在线观看| 欧美在线视频观看| 性欧美精品高清| 亚洲永久精品大片| 亚洲午夜日本在线观看| 99国产精品久久久久久久| 亚洲人成高清| 亚洲激情另类| 亚洲人成在线观看网站高清| 亚洲第一页自拍| 亚洲电影成人| 91久久香蕉国产日韩欧美9色 | 欧美大片在线观看| 美女视频黄a大片欧美| 久久露脸国产精品| 久久婷婷av| 欧美成va人片在线观看| 欧美激情精品久久久久久黑人| 欧美暴力喷水在线| 欧美日韩成人一区| 欧美日韩中文字幕日韩欧美| 欧美日韩一区二区高清| 欧美日韩美女一区二区| 欧美精品网站| 国产精品电影网站| 国产精品综合| 韩国一区电影| 亚洲激情视频在线| 9国产精品视频| 亚洲资源在线观看| 久久精品中文字幕一区二区三区 | 亚洲一区三区视频在线观看| 午夜精品国产精品大乳美女| 欧美国产综合视频| 在线一区二区视频| 亚洲第一精品夜夜躁人人爽 | 欧美18av| 国产精品久久久久久av下载红粉| 国产精品国产三级国产| 国产亚洲欧美日韩在线一区| 亚洲欧洲在线看| 亚洲一区二区在线| 久久精品国产亚洲精品| 欧美高清视频一二三区| 99热免费精品| 久久久噜噜噜久久狠狠50岁| 欧美另类极品videosbest最新版本| 欧美系列精品| 亚洲高清三级视频| 亚洲午夜日本在线观看| 免费欧美在线| 亚洲一区二区在线播放| 久久婷婷人人澡人人喊人人爽| 欧美日韩成人综合天天影院| 国产主播精品在线| 夜夜嗨av一区二区三区四区| 久久精品在线视频| 99视频在线观看一区三区| 欧美在线观看视频| 欧美视频一区二| 亚洲国产精品成人一区二区| 亚洲欧美国产77777| 亚洲高清视频在线| 香蕉乱码成人久久天堂爱免费| 欧美激情视频一区二区三区不卡| 国产欧美一区二区精品性| 99国产精品| 欧美激情按摩在线| 久久精品国产亚洲精品| 乱码第一页成人| 亚洲一区二区在线免费观看| 欧美激情中文不卡| 亚洲黄色免费网站| 久久综合九色99| 午夜久久资源| 国产精品视频网|