• <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ū)別重要在:
            一個(gè)是: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); 
            }                              

            一個(gè)是: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( )
            {
                  //當(dāng)然這里本來(lái)就寫得不好,要先顯式申明寫局部變量......
                  // 看你了解多少,討論討論兩種執(zhí)行可能的執(zhí)行路徑,即:FunctionTemplate的調(diào)用路徑?。?!
                  ::max( 4, 10 ,15 );


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

            評(píng)論

            # 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ù)應(yīng)該被匹配調(diào)用,跟聲明的前后沒(méi)關(guān)系

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

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

            上面是我讀一本書測(cè)試過(guò)的例子,書中曾說(shuō):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:,這里的意思比較適合第二種情況,即”一個(gè)是:inline int const& max申明在template <typename T>
            inline T const& max之后?!保覜](méi)有能在其他C++編譯器上測(cè)試過(guò),不知道C++標(biāo)準(zhǔn)中是否規(guī)定FunctionTemplate Resolution Rules,如果沒(méi)有,依據(jù)上面的英文描述,不同編譯器有不同的FunctionTemplate Resolution Rule,有可能template <typename T>
            inline T const& max (T const& a, T const& b, T const& c) 不可見(jiàn)到申明在后的inline int const& max。

            大家的意見(jiàn)呢?  回復(fù)  更多評(píng)論   

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

            無(wú)意闖到這邊來(lái)了。

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

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

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

            <c++ template>上說(shuō)必須把重載的寫在template的前面,然而我在vs2003上的測(cè)試是無(wú)所謂,至于標(biāo)準(zhǔn)上怎么說(shuō)那我就不知道了,寫在前面就一定保險(xiǎn),寫在后面估計(jì)是有危險(xiǎn)!  回復(fù)  更多評(píng)論   

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

            這玩意跟C的先申明后使用是一脈相承的吧,template的很多編譯策略都是看起來(lái)能用就行,不會(huì)顧及全面的  回復(fù)  更多評(píng)論   

            蜜臀久久99精品久久久久久小说 | 久久精品人人槡人妻人人玩AV| 精品久久久中文字幕人妻| 欧美性大战久久久久久| 99蜜桃臀久久久欧美精品网站| 亚洲国产精品18久久久久久| AV无码久久久久不卡蜜桃| 久久久国产精品网站| 国产69精品久久久久APP下载| 精品国产乱码久久久久久1区2区| 久久99精品国产99久久| 国内精品久久久久久久coent| 久久精品国产免费观看三人同眠| 国产精品久久久亚洲| 国产高潮国产高潮久久久91 | 久久久久久久久久久久久久| 久久精品国产精品亚洲| 欧美成人免费观看久久| 久久精品国产亚洲沈樵| 亚洲国产精品成人久久蜜臀| 97精品国产91久久久久久| 2021最新久久久视精品爱 | 国产综合精品久久亚洲| 青草国产精品久久久久久| 日本精品久久久久久久久免费| 97久久超碰国产精品旧版| 精品国产乱码久久久久久浪潮| 91精品国产乱码久久久久久| 伊人久久无码中文字幕| 一级a性色生活片久久无| 久久免费线看线看| 国产精品久久久久9999高清| 天天爽天天狠久久久综合麻豆| 狠狠色丁香婷婷久久综合| 久久精品免费观看| 91精品国产综合久久香蕉| 久久香蕉国产线看观看99| 国产成人久久久精品二区三区 | 亚洲欧美另类日本久久国产真实乱对白 | 国产成人无码久久久精品一| 亚洲精品97久久中文字幕无码 |