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

            Edgard

            討論FunctionTemplate申明的隱藏性(Visibility)

            看看兩端代碼,區(qū)別重要在:
            一個是:inline int const& max申明在template <typename T>
            inline T const& max之前。


            // maximum of two int values
            inline int const& max (int const& a, int const& b)
            {
                return a<b?b:a;
            }

            // maximum of two values of any type
            template <typename T>
            inline T const& max (T const& a, T const& b)
            {
                return a<b?b:a;
            }

            // maximum of three values of any type
            template <typename T>
            inline T const& max (T const& a, T const& b, T const& c)
            {
                return max (max(a,b), c); 
            }                              

            一個是:inline int const& max申明在template <typename T>
            inline T const& max之后。

            // maximum of two values of any type
            template <typename T>
            inline T const& max (T const& a, T const& b)
            {
                return a<b?b:a;
            }

            // maximum of three values of any type
            template <typename T>
            inline T const& max (T const& a, T const& b, T const& c)
            {
                return max (max(a,b), c); 
            }

            // maximum of two int values
            inline int const& max (int const& a, int const& b)
            {
                return a<b?b:a;
            }

            調(diào)用程序:
            int main( )
            {
                  //當然這里本來就寫得不好,要先顯式申明寫局部變量......
                  // 看你了解多少,討論討論兩種執(zhí)行可能的執(zhí)行路徑,即:FunctionTemplate的調(diào)用路徑!!!
                  ::max( 4, 10 ,15 );


            posted on 2005-12-15 21:10 Edgard 閱讀(531) 評論(5)  編輯 收藏 引用

            評論

            # re: 討論FunctionTemplate申明的隱藏性(Visibility) 2005-12-16 10:26 小明

            Function templates can be overloaded with nontemplate functions. All else being equal, the nontemplate function is preferred in Function templates can be overloaded with nontemplate functions. All else being equal, the nontemplate function is preferred in selecting the actual function being called. The following example illustrates this:

            // details/nontmpl.cpp

            #include <string>
            #include <iostream>

            template<typename T>
            std::string f(T)
            {
            return "Template";
            }

            std::string f(int&)
            {
            return "Nontemplate";
            }

            int main()
            {
            int x = 7;
            std::cout << f(x) << std::endl;
            }
            This should output:

            Nontemplate


            以上是C++ templates的原文。
            所以nontemplate的函數(shù)應該被匹配調(diào)用,跟聲明的前后沒關(guān)系

              回復  更多評論   

            # re: 討論FunctionTemplate申明的隱藏性(Visibility) 2005-12-16 12:47 Edgard

            上面是我讀一本書測試過的例子,書中曾說:This is only one example of code that might behave differently than expected as a result of detailed overload resolution rules. For example, the fact that not all overloaded functions are visible when a corresponding function call is made may or may not matter. In fact, defining a three-argument version of max() without having seen the declaration of a special two-argument version of max() for ints causes the two-argument template to be used by the three-argument version:,這里的意思比較適合第二種情況,即”一個是:inline int const& max申明在template <typename T>
            inline T const& max之后。”,我沒有能在其他C++編譯器上測試過,不知道C++標準中是否規(guī)定FunctionTemplate Resolution Rules,如果沒有,依據(jù)上面的英文描述,不同編譯器有不同的FunctionTemplate Resolution Rule,有可能template <typename T>
            inline T const& max (T const& a, T const& b, T const& c) 不可見到申明在后的inline int const& max。

            大家的意見呢?  回復  更多評論   

            # re: 討論FunctionTemplate申明的隱藏性(Visibility) 2005-12-17 15:08 清風雨

            無意闖到這邊來了。

            我是在對幾個概念不太清楚的情況下,想找找說明。本來是不管這些概念的,但,我想試試特化是不小心寫錯了,編譯器告訴我無法顯示化。
            我就納悶了,特化、偏特化、顯示化,所以,想找找概念的介紹,一不小心發(fā)現(xiàn)了這個blog站,而你說的問題,我又忍不住想開一下口。^_^

            關(guān)于特化的匹配原則,就像我們期望的那樣,編譯器是優(yōu)選最接近的。
            最簡單的測試方法,就是針對模板圓形,特化形式分別給出不同輸出,這樣,一眼便能知道編譯器選了誰。  回復  更多評論   

            # re: 討論FunctionTemplate申明的隱藏性(Visibility) 2006-01-08 20:27 chenchen

            <c++ template>上說必須把重載的寫在template的前面,然而我在vs2003上的測試是無所謂,至于標準上怎么說那我就不知道了,寫在前面就一定保險,寫在后面估計是有危險!  回復  更多評論   

            # re: 討論FunctionTemplate申明的隱藏性(Visibility) 2007-05-27 23:37 xiongx

            這玩意跟C的先申明后使用是一脈相承的吧,template的很多編譯策略都是看起來能用就行,不會顧及全面的  回復  更多評論   

            久久精品国产亚洲AV香蕉| 久久精品国产亚洲av麻豆色欲| 久久精品国产精品亚洲人人 | 99国产精品久久久久久久成人热| 国产精品禁18久久久夂久| 狠狠色综合网站久久久久久久| 亚洲?V乱码久久精品蜜桃| 亚洲精品蜜桃久久久久久| 99久久99久久精品国产片| 久久久久亚洲AV无码网站| 欧美性大战久久久久久| 国内精品久久九九国产精品| 色综合久久88色综合天天 | 久久久精品人妻一区二区三区蜜桃 | 囯产精品久久久久久久久蜜桃| 国产精品一久久香蕉产线看| 久久精品国产免费观看三人同眠| 国产成人99久久亚洲综合精品| 久久天堂AV综合合色蜜桃网| 久久这里都是精品| 久久最新免费视频| 国产精品九九久久精品女同亚洲欧美日韩综合区 | 久久99精品国产麻豆不卡| 久久国产精品无码一区二区三区 | 久久成人国产精品| 久久精品中文无码资源站| 欧美亚洲日本久久精品| 久久久久人妻精品一区三寸蜜桃| 99久久国产综合精品成人影院| 国产午夜福利精品久久2021 | 九九热久久免费视频| 中文字幕成人精品久久不卡| 亚洲国产成人久久精品动漫| 亚洲伊人久久大香线蕉苏妲己| 久久精品国产亚洲综合色| 国产ww久久久久久久久久| 丰满少妇人妻久久久久久4| 精品无码久久久久久久久久| 人人狠狠综合久久亚洲| 日韩精品久久久久久久电影| 亚洲中文字幕无码久久精品1|