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

            雁過無痕

              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::

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


             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



            浮點數與整型進行比較時,默認整型轉為浮點數


            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 閱讀(1372) 評論(5)  編輯 收藏 引用

            評論

            # re: 支持不同類型的 min 函數 2011-04-01 09:34 溪流
            對內建類型來說,sizeof 誰大就轉到誰,也不是最合理的
            比如int->double,我認為應該可以轉換;而float->long long呢?貌似應該不認為可轉換吧  回復  更多評論
              

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

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

            我采用:sizeof 誰大就轉到誰,
            是因為:對 long long 轉 float 的情況, 轉換很可能造成數據錯誤
            (float無法表示所有的long數),寫代碼時,不應該允許這樣的隱式轉換。
            應該顯示的轉為float。

            另外,還假定了不允許 int和unsigned int等
            有符號類型和相應的無符號類型進行比較
              回復  更多評論
              

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

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

            兩個數必須類型一致才能比較(不一 致時,要進行隱式轉換)。
            當 long long 和 float 進行比較時,C++默認是將long long轉為float,因為
            float能表示的數的范圍更廣,但這可能帶來錯誤的結果,
            比如說:
            float f = 1 << 29;
            long long k = (1<<29)+1;

            因此,調用者有責任將它們先轉為同一類型再進行比較,比如都轉為:double。

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

              回復  更多評論
              

            亚洲精品无码久久久久| 无码乱码观看精品久久| 久久精品人人做人人爽97| 狠狠色丁香久久婷婷综合五月| 久久久久高潮毛片免费全部播放 | 超级97碰碰碰碰久久久久最新| 综合久久久久久中文字幕亚洲国产国产综合一区首 | 久久久久国产精品人妻| 久久精品国产亚洲77777| 久久久久无码精品| 久久精品亚洲精品国产色婷| 久久天天躁狠狠躁夜夜2020老熟妇| 国产成人综合久久精品红| 91久久精品国产成人久久| 一级做a爰片久久毛片看看| 久久久久四虎国产精品| 久久人人爽人人人人爽AV | 欧美牲交A欧牲交aⅴ久久| 国产激情久久久久影院小草| 亚洲中文字幕久久精品无码喷水 | 亚洲va国产va天堂va久久| 国产精品欧美亚洲韩国日本久久| 777午夜精品久久av蜜臀| 中文字幕久久精品 | 亚洲v国产v天堂a无码久久| 99久久综合狠狠综合久久止| 久久精品国产亚洲AV香蕉| 午夜精品久久久久成人| 久久影院亚洲一区| 久久伊人中文无码| 四虎影视久久久免费观看| 国产精品九九久久免费视频| AA级片免费看视频久久| 国产精品欧美亚洲韩国日本久久 | 久久天天躁夜夜躁狠狠躁2022| 久久亚洲中文字幕精品一区四| 国产亚洲精午夜久久久久久| 色综合久久综精品| 久久九九久精品国产| 久久久久久亚洲精品不卡| 日本久久中文字幕|