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

隨筆 - 31  文章 - 128  trackbacks - 0
<2007年1月>
31123456
78910111213
14151617181920
21222324252627
28293031123
45678910

常用鏈接

留言簿(5)

隨筆分類(38)

隨筆檔案(31)

收藏夾(4)

College

High School

最新隨筆

搜索

  •  

積分與排名

  • 積分 - 56685
  • 排名 - 407

最新評論

  • 1.?re: [yc]詳解link
  • 面試的時候面試官就問過我什么是編譯和鏈接,我說編譯就是把代碼文件生成目標文件,鏈接就是把目標文件生成可執行文件,他說不對,又問我什么是動態鏈接,還問我預編譯都做什么處理。。。都在這里找到了答案!!!!
  • --王至乾
  • 2.?re: [yc]詳解link
  • @劉偉
    我是說博主,不是叫你啊
  • --溪流
  • 3.?re: [yc]詳解link
  • 誰是石老師,我不是哈@溪流
  • --劉偉
  • 4.?re: [yc]詳解link
  • 石老師?我是溪流~
  • --溪流
  • 5.?re: [yc]詳解link
  • 期待樓主下文啊,多謝樓主了
  • --劉偉

閱讀排行榜

評論排行榜

 

1。符號查找(對于函數此時只看名字,不看參數)
    大致順序是
    (1)如果有限定名( XXX:: )那么就直接在XXX里查找
    (2)函數局部名字空間
    (3)(如果是成員)類名字空間
    (4)遞歸向上至所有基類的名字空間
    (5)當前名字空間
    (6)遞歸向外至所有外層名字空間,
    在任一層里, 用using導入的符號和該層的其他符號同一對待。
    keonig查找: 對于函數, 如果參數為類/結構/模版類并位于其他的名字空間,
    在(5)和(6)的查找中導入該空間(不遞歸向外)的符號一同查找.

2。(如果是函數)重載決議(注意此時特化的函數不參與決議)

3。(如果是類內部的名字)檢查訪問權(注意此時特化的函數仍然不參與決議)

4。(如果找到了一個模版)模版特化決議

 

編譯器執行以上步驟的時候是使用貪心匹配,只要找到一個符合當前檢查內容的就會停止查

所以任何一層都有可能發生錯誤的掩蓋情況

例1

 1 void  f( int ) {}
 2 class  Y
 3 {
 4 public :
 5      void  f() {}
 6     Y()
 7      {
 8         f( 1 );
 9     }

10 }
;


這里的f(2)在1.(2)這里找到了符號f,就不會向上到1.(5)查找到真正的f(int)了

例2

void  g( int ) {}
namespace  S
{
    
void  g() {}

    
void  h()
    
{
        g(
1 );
    }

}


這里的g(1)在1.(5)這里找到了符號g,就不會向上到1.(6)查找到真正的g(int)了

例3

class  Y
{
    
void  f( int ) {}   // [1]
public :
    
void  f( double ) {}   // [2]
}
;

int  main()
{
    Y y;
    y.f(
1 );
}


y.f(1)會調用[2]嗎?不會,因為在第2步重載決議的時候就選定[1]了,因此這段代碼會報
出無法訪問private成員的錯誤

例4

template  < typename T >
void  f(T) {}   // [1]

template 
< typename T >
void  f(T * ) {}   // [2]

template 
<>
void  f < int *> ( int * ) {}   // [3]


int  main()
{
    
int   * =   0 ;
    f(p);
}


這里的f(p)會調用[3]嗎?
不會,因為在進行到第二步重載決議的時候,只有[1]和[2]參與了重載決議,結果選擇了
[2],那么[1]的特化版本[3]當然就輪不到了。

例5

class  X
{
    template 
< typename T >   void  g()  {}
public :
    template 
<>   void  g < int > () {}
}
;

int  main()
{
    X y;
    y.g
< int > ();
}


這里首先第3步訪問檢查發現g為private(此時g的特化版本被直接無視了),所以即使
g<int>為public, 該段代碼仍然不能夠編譯通過

例6

namespace  E
{
    
class  X {} ;
    
void  f(X) {}   // [1]
}


void  f(E::X) {}    // [2]

class  X
{
public :
    
void  f() {}   // [3]
     void  g()
    
{
        E::X x;
        f(x); 
// [4]
    }

}
;

[4]會調用那個呢? 在1.(3)里就確定了是[3],因此參數不匹配
如果注釋掉[3]的f,那么由于koenig查找, 在1.(5)里[1]和[2]都會是平等的可選項
所以會出現二義性.
如果把namespace E改為class E, 把E中的f改為靜態函數
由于koenig查找僅僅導入參數的名字空間, 因此[1]將不參與1.(5)的查找,
最終結果會是[2]

 

例7
這是一個現實中的例子,如果想給std::pair寫一個ostream的輸出函數,應該如何實現呢?

template<class U, class V>   
ostream
& operator<<(ostream& s, const pair<U, V>& p)   
{   
    
return s << p.first << " : " << p.second;   
}

差不多該這樣吧

但是如下代碼就會導致出錯
map<stringstring> a;     
copy(m.begin(), m.end(), ostream_iterator
<pair<stringstring> >(s, "\n"));
為什么呢?
因為在ostream_iterator的實現代碼里調用了pair的operator<<
由于ostream_iterator的代碼是在std名字空間里的,因此編譯器會首先在std里查找是否存在operator<<
一旦找到(盡管找到的operator<<不是給pair使用的),就不會繼續到全局名字空間里查找我們自己定義的operator<<了
因此解決方案是把自定義的operator<<放到std名字空間里
namespace std
{
    template
<class U, class V>   
    ostream
& operator<<(ostream& s, const pair<U, V>& p)   
    {   
        
return s << p.first << " : " << p.second;   
    }   
}
就可以了

例8
傳說中的hide
struct A
{
   
void f(int){}
};
struct B: public A 
{
   
void f(void){}
};

int main()
{
   B b;
   b.f(
1);
}

b.f(1)能編譯通過嗎?不能,因為編譯器會首先在B的名字空間里查找f,找到了void f(void),然后就會停止查找
因此A里的f(int)根本就沒有機會被編譯器訪問到
posted on 2006-12-27 11:04 shifan3 閱讀(2148) 評論(8)  編輯 收藏 引用 所屬分類: C++

FeedBack:
# re: 總結一下C++的名稱查找順序 2007-01-03 16:19 大熊貓
對特化不大了解,不知道特化用在什么地方,看起來只要有模板函數,編譯器就無視特化函數,能舉個編譯器不無視特化函數的例子嗎?  回復  更多評論
  
# re: 總結一下C++的名稱查找順序 2007-01-04 14:10 Francis Arcanum
@大熊貓
如果沒有重載的函數,或者重載決議決定使用有特化版本的函數,那么該函數特化版本就不會被無視了。

例如
template <typename T>
void f(T){} //1

template <>
void f<int>(int){} //2
這里沒有重載,所以直接考慮特化
或者
template <typename T>
void f(T){} //1

template <typename T>
void f(T*){} //2,對1重載

template <>
void f<int>(int*){} //3, 對2特化

調用
int *p = 0;
f(p);
這里重載決議選擇了2,那么2的特化版本3就會被納入考慮范圍了

  回復  更多評論
  
# re: 總結一下C++的名稱查找順序 2007-01-04 19:26 大熊貓
是不是在沒有重載的情況下,編譯器找到一個符合內容的就會符號就會地址搜索,所以例5中的那個特化沒有被考慮呢?  回復  更多評論
  
# re: 總結一下C++的名稱查找順序 2007-01-05 02:06 Francis Arcanum
@大熊貓
例5是因為判斷訪問權是在處理特化之前
所以還沒開始找特化版本編譯器就發現了錯誤,不會繼續下去了

另外對于符號搜索,針對第一步
其中每一個小步如果找到符合的符號,都會直接結束符號搜索

而2、3、4等步是在找到符號的那一層里進行操作  回復  更多評論
  
# re: 總結一下C++的名稱查找順序 2007-01-05 13:02 大熊貓
謝謝您
我還是弄大不懂
你的意思說編譯器看到y.g<int>(),查找到那個模板函數以后就不繼續找了,因為它是私有的,就直接報錯了(盡管還有一個公有的特化版本)。那如果不是私有的,那么它就準備實例化,當實例化的時候它還會去查符號?然后發現一個特化的版本,然后又調用了特化版本的?  回復  更多評論
  
# re: 總結一下C++的名稱查找順序 2007-01-05 13:16 大熊貓
void f(T) {} // [1]

template < typename T >
void f(T * ) {} // [2]

template <>
void f < int *> ( int * ) {} // [3]
void f(int *)
{
cout<<"111"; //[4]
}
int _tmain(int argc, _TCHAR* argv[])
{

int * p = 0 ;
f(p);
int pause;
cin>>pause;

return 0;
}
我又加了一個函數,我想問一下,在這個小程序里,編譯到底有沒有對二個模板函數做重決呢?難道編譯器先對二個模板函數進行重載的決議,然后決定哪個模板更好一些,然后再在實例化的時候,在比較匹配的模板所有可能的實例化版本和它的特化版本,還有函數4,中選擇一個最佳。不好意思,不知道有沒有表達清楚我的意思。  回復  更多評論
  
# re: 總結一下C++的名稱查找順序 2007-01-05 13:31 大熊貓
@Francis Arcanum
有點明白了,如果出現像上述小程序中的4函數,因該一開始編譯器就決定用它。如果沒有的話,再在二個模板函數中進行判斷,決定使用哪一個。然后發現是個模板函數,要實例化了,看見一個很匹配的特化版本,就直接用它了,對嗎? 上課要遲到了,哈哈,謝謝兄弟~。  回復  更多評論
  
# re: 總結一下C++的名稱查找順序 2007-01-05 16:00 Francis Arcanum
@大熊貓
這里1,2,4進行重載,則直接選擇了4
3在重載決議的時候不考慮。
如果重載決議選擇了1,那么就在1和3里面選擇

在重載決議的時候,1,2,4是平等的。但是4最匹配。
如果理解為先考慮非模板函數4,再考慮模板函數1、2,其實效果也完全一樣。  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
              久久蜜桃精品| 欧美激情国产日韩| 亚洲国产精品电影| 国模大胆一区二区三区| 国产日韩欧美在线| 国产一区二区三区直播精品电影| 一区二区三区四区国产精品| 激情久久影院| 亚洲国产cao| 99亚洲视频| 午夜精品美女久久久久av福利| 国产精品资源| 欧美性久久久| 国精品一区二区| 亚洲精品欧美一区二区三区| 亚洲一区二区三区在线| 久久国产88| 亚洲第一毛片| 亚洲视屏一区| 久久亚洲欧洲| 国产精品国产馆在线真实露脸 | 亚洲伊人一本大道中文字幕| 99在线热播精品免费99热| 亚洲欧美国产视频| 久久免费精品视频| 欧美激情国产高清| 国产欧美日韩精品专区| 亚洲经典自拍| 久久久国产午夜精品| 亚洲激情视频网| 欧美在线视频免费观看| 欧美日韩精品久久久| 国产亚洲综合性久久久影院| 日韩亚洲不卡在线| 久久精品首页| 亚洲少妇中出一区| 蜜月aⅴ免费一区二区三区| 国产精品区一区二区三区| 亚洲欧洲另类国产综合| 久久精品日韩| 久久一区二区三区四区| 久久久久成人精品| 国产精品国产精品| 亚洲美女免费视频| 久久天堂av综合合色| 亚洲一区二区综合| 欧美日韩高清免费| 亚洲日本免费| 欧美jizzhd精品欧美巨大免费| 午夜精品久久久久久99热软件| 亚洲人精品午夜| 久久国产视频网| 亚洲专区国产精品| 欧美亚州在线观看| 夜夜嗨av色综合久久久综合网| 亚洲日本中文字幕| 免费观看在线综合色| 欧美在线地址| 国产综合一区二区| 久久精品五月| 欧美在线日韩在线| 国内外成人免费激情在线视频网站| 国产香蕉久久精品综合网| 亚洲一区不卡| 亚洲素人在线| 国产美女一区| 午夜一区二区三区在线观看| 一本一道久久综合狠狠老精东影业| 亚洲私人影院| 国产精品qvod| 欧美亚洲综合在线| 欧美一区二区三区四区在线观看地址 | 国产精品日韩高清| 亚洲影音先锋| 亚洲欧美日韩精品久久| 国产日韩欧美一区| 久久国内精品自在自线400部| 久热精品视频在线观看| 久久精品国产精品亚洲| 亚洲成色精品| 亚洲激情一区二区三区| 欧美日韩精品| 先锋影院在线亚洲| 久久精品一区二区三区四区| 亚洲第一网站免费视频| 亚洲电影一级黄| 欧美色欧美亚洲高清在线视频| 国产日本欧美在线观看| 亚洲欧美成人精品| 先锋a资源在线看亚洲| 激情小说另类小说亚洲欧美| 欧美成人免费va影院高清| 欧美精品激情| 欧美一级久久久| 久久夜色精品一区| 亚洲欧美日韩国产精品| 亚洲第一区在线观看| 久久久久亚洲综合| 欧美黄色一级视频| 欧美呦呦网站| 欧美欧美天天天天操| 欧美在线视频在线播放完整版免费观看| 久久免费黄色| 免费成人av在线看| 午夜激情亚洲| 欧美高清视频在线观看| 久久不射网站| 欧美日本在线| 免费欧美日韩国产三级电影| 国产精品久久激情| 亚洲欧洲精品一区二区精品久久久| 久久精品国产亚洲精品| 日韩亚洲欧美高清| 欧美一区二区三区婷婷月色| 亚洲私人影院在线观看| 久久精品免费看| 亚洲欧美一区二区三区久久| 欧美成人免费在线视频| 久久狠狠亚洲综合| 欧美精品粉嫩高潮一区二区| 狂野欧美激情性xxxx| 国产精品美女视频网站| 亚洲精品国产欧美| 亚洲第一级黄色片| 欧美在线网址| 久久福利一区| 国产欧美日韩三区| 亚洲一区二区三区国产| 亚洲一区二区三区午夜| 欧美日韩国产综合久久| 亚洲丰满在线| 亚洲国产一区二区在线| 久久婷婷国产综合国色天香| 久久久久久久97| 国产女人18毛片水18精品| 亚洲午夜精品国产| 亚洲综合精品自拍| 国产精品国产三级国产| 99综合在线| 亚洲一区二区三区国产| 欧美亚一区二区| 一区二区三区视频在线| 亚洲一区自拍| 国产精品中文在线| 欧美一区二区免费| 久久综合伊人| 亚洲激情国产| 欧美理论在线播放| 99国产麻豆精品| 亚洲一区中文| 国产一区二区三区四区老人| 欧美伊人久久| 狼人天天伊人久久| 亚洲激情在线激情| 欧美日韩在线视频首页| 在线视频日韩精品| 久久av最新网址| 有坂深雪在线一区| 欧美国产一区视频在线观看| 亚洲精品在线观| 欧美综合77777色婷婷| 国产一区二区三区在线播放免费观看 | 一区二区欧美激情| 欧美精品www在线观看| 一个色综合av| 性欧美办公室18xxxxhd| 国际精品欧美精品| 欧美黑人国产人伦爽爽爽| 夜夜爽av福利精品导航| 久久久久久国产精品mv| 亚洲精品综合精品自拍| 欧美日韩一区在线视频| 午夜在线a亚洲v天堂网2018| 欧美成人免费网| 亚洲一区三区视频在线观看| 国产真实乱偷精品视频免| 欧美精品 国产精品| 亚洲女同同性videoxma| 亚洲大胆人体视频| 亚洲一区制服诱惑| 亚洲国产精品成人综合| 国产精品欧美一区喷水| 久久婷婷丁香| 亚洲欧美国产三级| 亚洲国产日韩欧美一区二区三区| 国产午夜精品一区二区三区视频| 美女在线一区二区| 91久久视频| 国产亚洲在线观看| 欧美日韩久久不卡| 久久久之久亚州精品露出| 一区二区三区免费观看| 蜜臀va亚洲va欧美va天堂| 亚洲欧美日韩中文在线制服| 亚洲精品欧美日韩专区| 国精品一区二区三区| 欧美性大战久久久久| 欧美精品黄色| 欧美成年人视频网站| 久久精品日韩欧美|