• <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>

            雁過無痕


            看見別人的帖子,也做了下。
            代碼只支持內(nèi)建類型。


             1#include <iostream>
             2
             3template<bool, typename T, typename F>
             4struct Select_type { typedef T R; };
             5
             6template<typename T, typename F>
             7struct Select_type<false, T, F> { typedef F R; };
             8
             9template<typename T, typename S> 
            10struct Larger_type {
            11  typedef typename Select_type<sizeof(T) >= sizeof(S), T, S>::R R;
            12}
            ;
            13
            14template<typename T, typename S>
            15typename Larger_type<T, S>::R min_value(T a, S b)
            16{
            17  return a < b ? a : b;
            18}

            19
            20
            21int main()
            22{
            23  int a = 2;
            24  double b = 1.2;
            25  std::cout << min_value(a, b) << " " << min_value(b, a) << "\n";
            26}

            27
            28



            浮點(diǎn)數(shù)與整型進(jìn)行比較時(shí),默認(rèn)整型轉(zhuǎn)為浮點(diǎn)數(shù)


            template
            <bool, typename T, typename F>
            struct Select_type { typedef T R; };

            template
            <typename T, typename F>
            struct Select_type<false, T, F> { typedef F R; };

            template
            <typename T> struct Type_rank
            static const int rank = 0; };

            template
            <> struct Type_rank<float>
            static const int rank = 21; };

            template
            <> struct Type_rank<double>
            static const int rank = 22; };

            template
            <> struct Type_rank<long double>
            static const int rank = 23; }

            template
            <typename T, typename S> 
            struct Larger_type {
              
            static const int fa = Type_rank<T>::rank;
              
            static const int fb = Type_rank<S>::rank;
              
            static const bool flag = fa > fb || (fa == fb && sizeof(T) >= sizeof(S));
              typedef typename Select_type
            <flag, T, S>::R R;
            }
            ;

            template
            <typename T> 
            struct Larger_type<T, T> { typedef T R;};

            template
            <typename T, typename S>
            typename Larger_type
            <T, S>::R min_value(T a, S b)
            {
              
            return a < b ? a : b;
            }

            posted on 2011-03-31 23:31 flyinghearts 閱讀(1394) 評(píng)論(5)  編輯 收藏 引用

            評(píng)論

            # re: 支持不同類型的 min 函數(shù) 2011-04-01 09:34 溪流
            對(duì)內(nèi)建類型來說,sizeof 誰大就轉(zhuǎn)到誰,也不是最合理的
            比如int->double,我認(rèn)為應(yīng)該可以轉(zhuǎn)換;而float->long long呢?貌似應(yīng)該不認(rèn)為可轉(zhuǎn)換吧  回復(fù)  更多評(píng)論
              

            # re: 支持不同類型的 min 函數(shù) 2011-04-01 18:44 so
            就是嘛,推導(dǎo)返回類型的為T和S兩類型中“較小”的那個(gè)。之前以為溪流要做的目地是根據(jù)實(shí)參a和b來推導(dǎo)返回類型呢。  回復(fù)  更多評(píng)論
              

            # re: 支持不同類型的 min 函數(shù) 2011-04-01 23:23 flyinghearts
            @溪流

            我采用:sizeof 誰大就轉(zhuǎn)到誰,
            是因?yàn)椋簩?duì) long long 轉(zhuǎn) float 的情況, 轉(zhuǎn)換很可能造成數(shù)據(jù)錯(cuò)誤
            (float無法表示所有的long數(shù)),寫代碼時(shí),不應(yīng)該允許這樣的隱式轉(zhuǎn)換。
            應(yīng)該顯示的轉(zhuǎn)為float。

            另外,還假定了不允許 int和unsigned int等
            有符號(hào)類型和相應(yīng)的無符號(hào)類型進(jìn)行比較
              回復(fù)  更多評(píng)論
              

            # re: 支持不同類型的 min 函數(shù) 2011-04-02 09:40 溪流
            @flyinghearts
            是的,應(yīng)該顯式轉(zhuǎn)換,但是我必須知道原始返回類型后,才能考慮如何轉(zhuǎn)換得到的結(jié)果。當(dāng)我寫下min(1LL, 2.0f) 的時(shí)候,我該認(rèn)為返回類型是什么呢?或者是你假定不允許寫下min(1LL, 2.0f)?請(qǐng)注意,當(dāng)寫下“min(1LL, 2.0f)”的時(shí)候,我并不了解min內(nèi)部做了什么,我只是認(rèn)為在比較他們的大小,不會(huì)猜到min里面會(huì)進(jìn)行類型轉(zhuǎn)換,因此不會(huì)寫成“min((float)1LL, 2.0f)”或者“min(1LL, (long long)2.0f)”。  回復(fù)  更多評(píng)論
              

            # re: 支持不同類型的 min 函數(shù) 2011-04-09 23:54 flyinghearts
            @溪流

            兩個(gè)數(shù)必須類型一致才能比較(不一 致時(shí),要進(jìn)行隱式轉(zhuǎn)換)。
            當(dāng) long long 和 float 進(jìn)行比較時(shí),C++默認(rèn)是將long long轉(zhuǎn)為float,因?yàn)?
            float能表示的數(shù)的范圍更廣,但這可能帶來錯(cuò)誤的結(jié)果,
            比如說:
            float f = 1 << 29;
            long long k = (1<<29)+1;

            因此,調(diào)用者有責(zé)任將它們先轉(zhuǎn)為同一類型再進(jìn)行比較,比如都轉(zhuǎn)為:double。

            我剛更新了代碼。可以通過rank的值大小,加上特化,控制類型的轉(zhuǎn)換。

              回復(fù)  更多評(píng)論
              


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


            久久99国产精品久久99| 久久精品欧美日韩精品| 久久66热人妻偷产精品9| 久久精品国产亚洲AV不卡| 漂亮人妻被中出中文字幕久久 | 国产精品久久久久9999| 亚洲精品国产美女久久久| 亚洲精品国产字幕久久不卡| 久久午夜伦鲁片免费无码| 国产精品久久久久久搜索| 久久中文字幕一区二区| 国产成人99久久亚洲综合精品| 国产成人精品久久亚洲高清不卡 国产成人精品久久亚洲高清不卡 国产成人精品久久亚洲 | 一本色道久久88综合日韩精品 | 日产精品99久久久久久| 国内精品久久久久久野外| 国产精品99久久久久久宅男| 久久久综合香蕉尹人综合网| 欧美国产精品久久高清| 伊人色综合久久天天人手人婷 | 久久久青草青青亚洲国产免观| 激情久久久久久久久久| 久久久久久精品无码人妻| 国产产无码乱码精品久久鸭| 国产精品综合久久第一页 | 亚洲AV无码久久寂寞少妇| 久久综合狠狠色综合伊人| 一级女性全黄久久生活片免费 | 国产成人综合久久久久久 | 久久精品成人欧美大片| 韩国无遮挡三级久久| 久久精品国产日本波多野结衣| 99久久成人国产精品免费| 伊人色综合久久天天网| 97久久久精品综合88久久| 欧美一级久久久久久久大片| 久久婷婷五月综合色奶水99啪| 久久夜色精品国产www| 久久99精品综合国产首页| 欧美亚洲国产精品久久| 久久本道久久综合伊人|