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

            VC++ C++ C# Algorithm

            C++博客 首頁 新隨筆 聯(lián)系 聚合 管理
              21 Posts :: 3 Stories :: 31 Comments :: 0 Trackbacks
            起因,昨天寫的一段小程序
            #include? < iostream >
            #include?
            < map >
            #include?
            < iterator >
            #include?
            < vector >
            #include?
            < algorithm >
            using ? namespace ?std;
            ostream?
            & operator << (ostream? & os, const ?pair < int , int > ? &
            mp)
            {
            ???os
            <<
            mp.first;
            ???os
            <<
            mp.second;
            ???
            return
            ?os;
            }

            int ?_tmain( int ?argc,?_TCHAR * ?argv[])
            {
            ???pair
            < int , int > ?mmp( 100 , 200
            );
            ???cout
            <<
            mmp;
            ???map
            < int , int >
            ?imap;
            ???map.insert(make_pair(
            100 , 100
            ));
            ???imap.insert(make_pair(
            22 , 123
            ));
            ???copy(imap.begin(),imap.end(),ostream_iterator
            < pair < int , int > ? > (cout, " \n "
            ));
            ???
            return ? 0
            ;
            }

            未能通過編譯,報(bào)的錯(cuò)誤是:沒有找到接受“<未知>”類型的右操作數(shù)的運(yùn)算符(或沒有可接受的轉(zhuǎn)換),百思不得其解,應(yīng)為我覺得 我明明重載了<<運(yùn)算符。再?zèng)]有辦法的情況下請(qǐng)教了CSDN論壇上的一些朋友,終于弄明白了其中的原因(可能這個(gè)知識(shí)點(diǎn)很菜,高手 不要見笑)。
            ostream_iterator<_Ty, _Elem, _Traits>& operator=(const _Ty& _Val)
            {
            ? *_Myostr << _Val;///~~~~~~~~~~~~~~~~~~~~~~~這是在ostream_iterator類源代碼當(dāng)中,就是這里報(bào)錯(cuò)了
            ? if (_Mydelim != 0)
            ? *_Myostr << _Mydelim;
            ? return
            }
            在上面那到程序當(dāng)中_Val類型是pair<int,int> *_Myostr類型是ostream,顯然這里出錯(cuò),代表編譯器就好像沒有看到我的重載。出現(xiàn)以上現(xiàn)象的原因就是當(dāng)編譯器看到*_Myostr<<_Val時(shí)候,它會(huì)先在自己的名字空間查找<<,這個(gè)估計(jì)發(fā)生在模板編譯的第一個(gè)階
            段(不知道是不是該這么說),它看到了一個(gè)范型的<<重載(估計(jì)),于是就不在去別的地方查找。可是到了實(shí)例化的時(shí)候,編譯器發(fā)現(xiàn) 沒有匹配的<<運(yùn)算,于是就報(bào)錯(cuò)了。如果我們把重載寫在std空間里,也就是和ostream_iterator一個(gè)空間里,編譯器在實(shí)例化的時(shí) 候也會(huì)把它納入考慮對(duì)象之一,這個(gè)時(shí)候它就會(huì)選擇我們的重載,一切就OK了。注意,如果編譯器在*_Myostr<<_Val所在名字空間沒有找到 <<重載,則它會(huì)進(jìn)行類型相關(guān)查找。就是去定義*_Myostr類型或_Va類型的空間查找,再找不到那它就會(huì)去全局空間去查找。
            個(gè)人理解,不是很肯定,誠請(qǐng)高手糾正,感謝CSDN上周星星和晨星。

            posted on 2006-12-29 19:42 大熊貓 閱讀(1871) 評(píng)論(13)  編輯 收藏 引用

            Feedback

            # re: c++名字查找 2006-12-30 02:40 Francis Arcanum
            http://www.shnenglu.com/shifan3/archive/2006/12/27/16902.html
            我的這篇文章也許對(duì)你有用  回復(fù)  更多評(píng)論
              

            # re: c++陳義忠 2007-01-14 22:44 陳義忠
            @Francis Arcanum
              回復(fù)  更多評(píng)論
              

            # re: c++名字查找 2007-02-15 10:35 郝志群
            查找郝志群地址  回復(fù)  更多評(píng)論
              

            # re: c++名字查找 2007-05-12 18:08 吳細(xì)珍
            我要找到此人  回復(fù)  更多評(píng)論
              

            # re: c++名字查找 2007-06-01 15:29 胡美愛
            既然的 "安康[ JMHD MNDB 我緊密功能反對(duì)恐懼
              回復(fù)  更多評(píng)論
              

            # re: c++名字查找 2007-06-18 16:11 李厚娟
            我愛她你不想我嗎?
              回復(fù)  更多評(píng)論
              

            # re: c++名字查找 2007-10-06 18:06 晚會(huì)垂柳
            sds  回復(fù)  更多評(píng)論
              

            # re: c++名字查找 2007-10-06 18:06 晚會(huì)垂柳
            dd  回復(fù)  更多評(píng)論
              

            # re: c++名字查找 2008-09-11 08:21 王疆
            所有內(nèi)容  回復(fù)  更多評(píng)論
              

            # re: c++名字查找 2008-09-11 08:23 王疆
            我要找到王疆
              回復(fù)  更多評(píng)論
              

            # re: c++名字查找 2008-10-24 17:48 黃建寧
            桔柑  回復(fù)  更多評(píng)論
              

            # re: c++名字查找 2009-02-25 11:53
            名字區(qū)碼  回復(fù)  更多評(píng)論
              

            # re: c++名字查找 2009-03-11 19:12 周敏楨
            是  回復(fù)  更多評(píng)論
              


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


            亚洲一级Av无码毛片久久精品| 久久996热精品xxxx| 97久久超碰国产精品2021| 久久国产亚洲精品麻豆| 亚洲国产成人精品无码久久久久久综合 | 亚洲AV日韩AV永久无码久久| 伊人久久大香线焦综合四虎| 亚洲国产美女精品久久久久∴| 99久久国产综合精品成人影院| 亚洲乱码精品久久久久.. | 国产精品乱码久久久久久软件| 无码精品久久久天天影视| 久久久精品日本一区二区三区 | 国产午夜精品久久久久九九电影| 东方aⅴ免费观看久久av| 久久久久久久综合综合狠狠| 亚洲国产精品婷婷久久| 久久久久成人精品无码中文字幕| 久久精品国产亚洲αv忘忧草| 色偷偷88欧美精品久久久 | 无码国内精品久久人妻蜜桃 | 久久精品国产精品青草| 精品国产99久久久久久麻豆| 久久亚洲高清综合| 精品久久久久中文字幕一区| 99久久精品费精品国产| 欧美精品一区二区精品久久| 69久久夜色精品国产69| 精品久久久久久无码中文字幕一区 | 99久久综合狠狠综合久久止| 91精品国产高清久久久久久io| 亚洲va中文字幕无码久久| 亚洲狠狠婷婷综合久久久久| 久久精品视频一| 久久久久亚洲AV无码专区体验| 一本一本久久A久久综合精品 | 亚洲午夜无码久久久久小说| 久久人人爽人人人人片av| 亚洲欧美久久久久9999| 亚洲色欲久久久综合网东京热| 久久亚洲美女精品国产精品|