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

隨筆-90  評(píng)論-947  文章-0  trackbacks-0

有個(gè)需求,能否做到實(shí)現(xiàn)一個(gè)類似這樣的函數(shù):

template <typename T1, typename T2>
XXX Min(T1 t1, T2 t2)
{
    return (t1 < t2 ? t1 : t2);
}

其中 XXX 是我們要推導(dǎo)出的類型。

以下是一個(gè)失敗的嘗試。

我記得 Loki 里有關(guān)于如何判斷某個(gè)類型能否隱式轉(zhuǎn)換為另一個(gè)類型的東西,大意如下:

template <typename T, typename U>
class Conversion
{
private:
    typedef char Small;
    class Big { char XXX[2]; };
    static Small Test(U);
    static Big Test(...);
    static T MakeT();
public:
    enum
    {
        Exists = (sizeof(Test(MakeT())) == sizeof(Small)),
    };
};

如此,Conversion<T, U>::Exists 就能判斷 T 到 U 的轉(zhuǎn)換是否存在了。

然后再搞個(gè)選擇:

template <bool Condition, typename TypeIfTrue, typename TypeIfFalse>
struct Select
{
    typedef TypeIfFalse Type;
};

template <typename TypeIfTrue, typename TypeIfFalse>
struct Select<true, TypeIfTrue, TypeIfFalse>
{
    typedef TypeIfTrue Type;
};

最后,再來個(gè):

struct NullType;

template <typename T, typename U>
struct CommonType
{
    typedef typename Select<Conversion<T, U>::exists,
                                        U,
                                        typename Select<Conversion<U, T>::exists,
                                                                T,
                                                                NullType>::Type
                                       >::Type Type;
};

那么 CommonType<T1, T2> 就是 T1 和 T2 之間哪個(gè)是他們的共有類型了。

測(cè)試:

int main()
{
    CommonType<int, double>::Type m = 0;

    return 0;
}

調(diào)試,確認(rèn) m 是 double 的。但是反過來寫 CommonType<double, int>::Type m = 0;,m 卻是 int 的。

這說明這套機(jī)制一開始就有問題,Test(U) 和 Test(…) 兩個(gè)重載函數(shù)中,Test(…) 不會(huì)在需要 double 轉(zhuǎn) int 時(shí)勝出。這是第一個(gè)問題。

第二個(gè)問題,當(dāng)寫下如下代碼的時(shí)候:

template <typename T1, typename T2>
CommonType<T1, T2>::Type Min(T1 t1, T2 t2)
{
    return (t1 < t2 ? t1 : t2);
}

編譯無法通過。原因是返回類型中的 CommonType 中的模板參數(shù) T、U 無法接受此時(shí)還不能確定的 T1、T2。

(更正:不是這個(gè)原因,返回類型前加 typename 即可。現(xiàn)在問題還是第一個(gè)問題。)

請(qǐng)教各位,有沒有什么方法做到?歡迎指教~

C++ 0x 中就能很方便做到了:

template <typename T1, typename T2>
auto Min(T1 t1, T2 t2) -> decltype(t1 + t2)
{
    return (t1 < t2 ? t1 : t2);
}

int main()
{
    int a = 2;
    double b = 1.0;
    auto m = Min(a, b);

    return 0;
}

posted on 2011-03-29 21:27 溪流 閱讀(1935) 評(píng)論(16)  編輯 收藏 引用 所屬分類: C++

評(píng)論:
# re: 如何實(shí)現(xiàn)一個(gè)支持不同類型的 max/min 函數(shù)? 2011-03-29 23:38 | so
我不知道0x的新概念。撇開不談。
請(qǐng)問一個(gè)min/max函數(shù)怎么根據(jù)兩個(gè)參數(shù)推倒返回值類型呢? 因?yàn)閰?shù)的比較是運(yùn)行時(shí)概念。
另外,實(shí)現(xiàn)出來有什么作用呢?  回復(fù)  更多評(píng)論
  
# re: 如何實(shí)現(xiàn)一個(gè)支持不同類型的 max/min 函數(shù)? 2011-03-30 00:36 | 陳梓瀚(vczh)
你都返回xxx?t1:t2了,那么T1跟T2只能相等。  回復(fù)  更多評(píng)論
  
# re: 如何實(shí)現(xiàn)一個(gè)支持不同類型的 max/min 函數(shù)? 2011-03-30 03:32 | gbb21
理論上是不可能的事情,C++的類型是靜態(tài)的,對(duì)運(yùn)行時(shí)確定的類型無法推倒~  回復(fù)  更多評(píng)論
  
# re: 如何實(shí)現(xiàn)一個(gè)支持不同類型的 max/min 函數(shù)? 2011-03-30 08:15 | 周星星
auto Min(T1 t1, T2 t2) -> decltype(t1 + t2)
應(yīng)該是
[] Min(T1 t1, T2 t2) -> decltype(t1 + t2)
吧  回復(fù)  更多評(píng)論
  
# re: 如何實(shí)現(xiàn)一個(gè)支持不同類型的 max/min 函數(shù)? 2011-03-30 08:31 | 溪流
@so
我不需要參數(shù)的數(shù)值大小,只需要知道類型信息啊,編譯期可以知道  回復(fù)  更多評(píng)論
  
# re: 如何實(shí)現(xiàn)一個(gè)支持不同類型的 max/min 函數(shù)? 2011-03-30 08:32 | 溪流
@陳梓瀚(vczh)
比如 T1 = int, T2 = double,我期望返回類型是 double  回復(fù)  更多評(píng)論
  
# re: 如何實(shí)現(xiàn)一個(gè)支持不同類型的 max/min 函數(shù)? 2011-03-30 08:33 | 溪流
@gbb21
這還沒到運(yùn)行時(shí)啊,模板函數(shù)特化的時(shí)候就知道了啊  回復(fù)  更多評(píng)論
  
# re: 如何實(shí)現(xiàn)一個(gè)支持不同類型的 max/min 函數(shù)? 2011-03-30 08:33 | 溪流
@周星星
不一定要 lambda 啊,單單一個(gè)普通函數(shù)就可以了,就像我原文里寫的那樣  回復(fù)  更多評(píng)論
  
# re: 如何實(shí)現(xiàn)一個(gè)支持不同類型的 max/min 函數(shù)? 2011-03-30 09:31 | 周星星
我在g++4.5中試了一下你的代碼,是正確的,用[]反而不對(duì)。
但我看維基百科中是這么寫的(和lambda語法類似,但不是lambda),在http://zh.wikipedia.org/wiki/C++0x 中搜索 “另一種的函數(shù)語法”  回復(fù)  更多評(píng)論
  
# re: 如何實(shí)現(xiàn)一個(gè)支持不同類型的 max/min 函數(shù)? 2011-03-30 09:45 | FF
關(guān)于第一個(gè)問題,是C++內(nèi)建類型的隱式轉(zhuǎn)換引起的,這需要禁止C++內(nèi)建類型的隱式轉(zhuǎn)換,如果不能禁用用,就對(duì)所有內(nèi)建類型重載Test函數(shù),這樣能夠避免內(nèi)建類型的轉(zhuǎn)換。

關(guān)于第二個(gè)問題,我覺得有點(diǎn)奇怪,我建議Select的第一個(gè)模板參數(shù)改為typename T_, 然后分別特化struct true_flag 和struct false_flag  回復(fù)  更多評(píng)論
  
# re: 如何實(shí)現(xiàn)一個(gè)支持不同類型的 max/min 函數(shù)? 2011-03-30 14:20 | 空明流轉(zhuǎn)
你這個(gè)問題無解。  回復(fù)  更多評(píng)論
  
# re: 如何實(shí)現(xiàn)一個(gè)支持不同類型的 max/min 函數(shù)? 2011-03-30 14:22 | 空明流轉(zhuǎn)
@溪流
不知道。  回復(fù)  更多評(píng)論
  
# re: 如何實(shí)現(xiàn)一個(gè)支持不同類型的 max/min 函數(shù)? 2011-03-30 14:25 | 溪流
@空明流轉(zhuǎn)
我現(xiàn)在倒是有了個(gè)不太完美的解法:

// 判斷 T 到 U 的轉(zhuǎn)換是否存在
template <typename T, typename U>
class Conversion
{
private:
typedef char Small;
class Big { char XXX[2]; };
static Small Test(U);
static Big Test(...);
static T MakeT();
public:
enum
{
Exists = (sizeof(Test(MakeT())) == sizeof(Small)),
};
};

// 以上對(duì)內(nèi)置類型的判斷還是不夠給力,
// 比如給出 T = int,U = double,它認(rèn)為可轉(zhuǎn)換;反過來,它還是認(rèn)為可轉(zhuǎn)換,只是多了個(gè) warning 而已。
// 所幸,這些內(nèi)置類型是有限的,我們可以采用人肉的方法,兩兩組合,分別給出偏特化版本。
// 簡潔起見,僅列出 int 和 double 兩個(gè)。
template <>
class Conversion<int, double>
{
public:
enum
{
Exists = true,
};
};

template <>
class Conversion<double, int>
{
public:
enum
{
Exists = false,
};
};


template <bool Condition, typename TypeIfTrue, typename TypeIfFalse>
struct Select
{
typedef TypeIfFalse Type;
};

template <typename TypeIfTrue, typename TypeIfFalse>
struct Select<true, TypeIfTrue, TypeIfFalse>
{
typedef TypeIfTrue Type;
};

struct NullType;

template <typename T, typename U>
struct CommonType
{
typedef typename Select<Conversion<T, U>::Exists,
U,
typename Select<Conversion<U, T>::Exists,
T,
NullType>::Type
>::Type Type;
};

template <typename T1, typename T2>
typename CommonType<T1, T2>::Type Min(T1 t1, T2 t2)
{
return (t1 < t2 ? t1 : t2);
}

int main()
{
int a = 0;
double b = 1;
CommonType<int, double>::Type m1 = Min(a, b);
CommonType<double, int>::Type m2 = Min(a, b);
int m3 = Min(a, b);
double m4 = Min(a, b);

return 0;
}


只是。。。太人肉了。。。
  回復(fù)  更多評(píng)論
  
# re: 如何實(shí)現(xiàn)一個(gè)支持不同類型的 max/min 函數(shù)? 2011-03-30 15:49 | somebody
template<class T1, class T2>
auto max(const T1 & t1, const T2 & t2)
->decltype(t1 >= t2 ? t1 : t2)
{
return t1 >= t2 ? t1 : t2;
}  回復(fù)  更多評(píng)論
  
# re: 如何實(shí)現(xiàn)一個(gè)支持不同類型的 max/min 函數(shù)? 2011-03-30 17:31 | 空明流轉(zhuǎn)
你這個(gè)和無解沒有任何區(qū)別。  回復(fù)  更多評(píng)論
  
# re: 如何實(shí)現(xiàn)一個(gè)支持不同類型的 max/min 函數(shù)? 2011-03-30 19:49 | 陳昱(CY)
好像內(nèi)置的都可以隱式轉(zhuǎn)換,先弄個(gè)判斷是否內(nèi)置類型的模板,再對(duì)內(nèi)置的類型直接判斷類型大小就夠了  回復(fù)  更多評(píng)論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            黑人巨大精品欧美一区二区| 欧美天堂亚洲电影院在线观看| 亚洲狠狠婷婷| 久久久久国产精品www | 鲁大师影院一区二区三区| 亚洲在线免费| 欧美丝袜第一区| 亚洲精品视频在线播放| 一本色道久久综合狠狠躁篇怎么玩 | 亚洲福利精品| 亚洲片在线观看| 能在线观看的日韩av| 亚洲二区精品| 亚洲精品一二区| 欧美片第一页| 亚洲视频免费观看| 久久久xxx| 亚洲第一网站免费视频| 免费欧美日韩| 亚洲国产精品ⅴa在线观看| 老鸭窝亚洲一区二区三区| 欧美华人在线视频| 夜夜嗨av一区二区三区四区 | 卡一卡二国产精品| 亚洲高清久久久| aa日韩免费精品视频一| 欧美午夜精彩| 午夜影院日韩| 男女激情视频一区| 99re热这里只有精品视频| 欧美午夜电影一区| 一区二区三区产品免费精品久久75 | 欧美影院视频| 精品成人在线视频| 欧美大片专区| 亚洲深夜福利| 女女同性精品视频| 一本久久精品一区二区| 国产精品国内视频| 欧美一区午夜精品| 亚洲国产精品久久久久秋霞蜜臀| 亚洲专区在线视频| 在线视频国产日韩| 国产精品xxxxx| 久久久xxx| 99视频+国产日韩欧美| 久久久人人人| 一本大道久久a久久精品综合| 国产色产综合产在线视频| 欧美激情成人在线视频| 亚洲欧美日韩一区二区| 欧美国产一区二区| 欧美一区二区三区日韩视频| 亚洲激情综合| 国产日产欧美精品| 欧美精品18+| 久久久99国产精品免费| 亚洲视频图片小说| 亚洲国内自拍| 久久精品国内一区二区三区| 一区二区三区久久| 亚洲夫妻自拍| 国产日韩欧美精品| 欧美三级免费| 欧美xxx成人| 久久久久久久尹人综合网亚洲| 日韩小视频在线观看| 欧美xxx在线观看| 久久丁香综合五月国产三级网站| 一区二区高清在线观看| 亚洲国产精选| 国产亚洲欧美一级| 欧美日韩一区二| 欧美激情bt| 美女国内精品自产拍在线播放| 欧美一级日韩一级| 中文亚洲视频在线| 一本色道久久综合精品竹菊| 亚洲福利专区| 免费日本视频一区| 久久一区二区三区av| 欧美综合激情网| 欧美一区二区视频在线观看2020| 野花国产精品入口| 亚洲国产日韩一级| 精品成人一区二区三区| 欧美精品一区二区三区蜜臀| 久久久综合网站| 欧美一区二区三区四区在线观看| 在线亚洲欧美视频| 日韩视频第一页| 亚洲精品在线一区二区| 亚洲电影av| 美女网站在线免费欧美精品| 久久精品毛片| 欧美自拍偷拍| 欧美专区日韩专区| 欧美一区二区三区在线免费观看| 亚洲欧美日韩精品| 亚洲尤物影院| 午夜精品久久久久久久久久久久久| 亚洲视频免费在线| 亚洲一区二区三区四区中文| 亚洲天堂成人在线观看| 亚洲小说欧美另类婷婷| 亚洲午夜视频在线观看| 亚洲一区二区影院| 性18欧美另类| 久久精品91久久香蕉加勒比 | 99re6这里只有精品| 99精品热6080yy久久| 亚洲影院高清在线| 欧美一级艳片视频免费观看| 欧美在线观看日本一区| 久久精品视频在线| 麻豆成人在线观看| 亚洲国产91精品在线观看| 亚洲另类视频| 亚洲综合久久久久| 久久精品99久久香蕉国产色戒| 久久亚洲精品伦理| 欧美精品在线观看一区二区| 欧美视频一区二区三区…| 国产精品久久久久久久9999| 国产欧美亚洲日本| 91久久久国产精品| 中日韩高清电影网| 欧美在线亚洲一区| 欧美国产视频日韩| 亚洲免费不卡| 久久国产99| 欧美日本国产一区| 国产精品视频免费观看www| 国内伊人久久久久久网站视频| 亚洲黄页一区| 校园春色综合网| 欧美激情1区2区| 一本一本a久久| 久久亚洲精选| 国产精品久久久久久久久婷婷 | 欧美高清在线一区| 国产精品一国产精品k频道56| 一区二区三区在线高清| 亚洲美女性视频| 午夜日韩福利| 欧美成人精品1314www| 一本色道久久综合亚洲精品按摩| 欧美在线视频播放| 欧美三级欧美一级| 在线观看国产精品淫| 亚洲欧美日韩一区二区在线 | 亚洲一级二级| 久久一区二区三区av| 99国产成+人+综合+亚洲欧美| 欧美主播一区二区三区| 欧美日韩精品三区| 在线观看中文字幕不卡| 亚洲欧美精品中文字幕在线| 欧美成人69| 午夜视频一区| 欧美午夜久久| 亚洲美女在线国产| 免费毛片一区二区三区久久久| 亚洲一区二区伦理| 欧美区在线播放| 黄色在线一区| 欧美一级电影久久| 一道本一区二区| 一区二区日本视频| 美女成人午夜| 影音先锋国产精品| 久久精品99无色码中文字幕 | 日韩视频在线你懂得| 久久蜜桃精品| 国语自产精品视频在线看一大j8 | 老司机免费视频一区二区三区| 国产精品黄色在线观看| 亚洲欧洲一区二区在线观看| 久久精品中文| 亚洲一区在线观看免费观看电影高清| 欧美黑人一区二区三区| 亚洲第一黄网| 久久一区二区三区四区| 亚洲欧美中文另类| 国产欧美精品| 欧美一级片在线播放| 亚洲性线免费观看视频成熟| 欧美区在线观看| 亚洲欧洲一级| 欧美aa在线视频| 老妇喷水一区二区三区| 一区在线电影| 美女性感视频久久久| 香蕉久久一区二区不卡无毒影院 | 国产亚洲精品美女| 久久国产精品久久久久久久久久 | 欧美综合国产| 国产一区久久| 噜噜噜噜噜久久久久久91| 久久久夜夜夜|