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

            martin

            thinking

            常用鏈接

            統(tǒng)計(jì)

            software

            最新評(píng)論

            模板與泛型算法

            前段時(shí)間讀了一本書(shū)《C++沉思錄》,偶有感,摘錄如下:
            模板和泛型算法(摘自 《c++沉思錄》):
             
            一個(gè)特例:
            1.假設(shè)我們希望從整數(shù)數(shù)組中找到第一個(gè)等于某給定值的元素.編寫(xiě)如下代碼:
            const int*
            find1(const int* array, int n, int x)
            {
                const int *p = array;
                for( int i = 0; i < n; i++)
                {
                    if(*p==x)
                        return p;
                    ++p;
                }
                return 0;
            }
             
            2.泛型化元素類(lèi)型:
            用類(lèi)型T來(lái)表示整型等,適當(dāng)?shù)臅r(shí)候可以把const也包含在T中,得到如下函數(shù).
            template<class T>
            T* find2(T* array, int n, constT& x)
            {
                T* p = array;
                for(int i=0; i<n; i++)
                {
                    if(*p==x)
                        return p;
                    ++p;
                }
                return 0;
            }
               
            3.推遲計(jì)數(shù).
            為了避免預(yù)先知道有多少個(gè)元素,我們改變函數(shù),使它接受指向第一個(gè)元素和最后一個(gè)元素之后元素的指針
            template<class T>
            T* find3(T* array, T* beyond, constT& x)
            {
                T* p = array;
                while(p!=beyond)
                {
                    if(*p ==x)
                        return x;
                    ++p;
                }
                return 0;
            }
            用!=而不用<來(lái)判斷循環(huán)結(jié)束并不是偶然.從某種角度來(lái)說(shuō),兩者沒(méi)有區(qū)別,如果find3的輸入有意義,則p就小于beyond,直到它們相等為止.但是,由<加以總體排序的類(lèi)型通常也能用!=來(lái)進(jìn)行比較.另一方面,考慮一下我們以后可能會(huì)用到來(lái)代替指針的類(lèi)型,他們可以很好地定義!=,但不一定能定義<.此時(shí),使用<就是一個(gè)不合理的假設(shè).
             
            另外,我們還假設(shè)了,0可以轉(zhuǎn)換成一個(gè)與其他所有的值不同的指針值.我們稍微做一點(diǎn)改變,以避免這種假設(shè):如果程序中要找的值沒(méi)找到,它就返回beyond而不是0.
            template<class T>
            T* find4(T* array, T* beyond, constT& x)
            {
                T* p = array;
                while(p!=beyond)
                {
                    if(*p ==x)
                        return x;
                    ++p;
                }
                return beyond;
            }
             
            因?yàn)槌绦蛞捶祷剡m當(dāng)?shù)腡*, 要么返回beyond.故程序代碼可以被修改如下:
            template<class T>
            T* find5(T* array, T* beyond, constT& x)
            {
                T* p = array;
                while(p!=beyond && *p != x)
                    ++p;
                return p;
            }
             
            4.地址的獨(dú)立性
             到目前為止,我們還是依賴(lài)于傳遞來(lái)的指針,該指針要指向要查找的數(shù)據(jù)的開(kāi)頭.但是如果仔細(xì)分析一下,會(huì)發(fā)現(xiàn)我們只依賴(lài)于指針的某些保留特性:
            1)可以把指針當(dāng)參數(shù)接收,并把它們作為結(jié)果返回.
            2)可以比較指針是否相等.
            3)可以解除引用,以便得到值:*p.
            4)可以遞增,以指向下一個(gè)元素.
             
            只要符合上述條件的類(lèi)型即可,不一定是指針類(lèi)型.假設(shè)把T*作為模板參數(shù),我們就取消了對(duì)指針的依賴(lài):
            template<class P,class T>
            T* find6(P start, p beyond, constT& x)
            {
                while(start !=beyond && *start != x)
                    ++start;
                return start;
            }
             
            我們已經(jīng)完全剔除了函數(shù)中關(guān)于具體類(lèi)型的信息.根本沒(méi)有要求p是指針,只要求p滿(mǎn)足上述的四個(gè)特性.
             

             

            posted on 2009-03-06 17:43 martin_yahoo 閱讀(1807) 評(píng)論(3)  編輯 收藏 引用

            評(píng)論

            # re: 模板與泛型算法 2009-03-06 23:29 Santhtony

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

            # re: 模板與泛型算法[未登錄](méi) 2009-03-08 09:25 908971

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

            # re: 模板與泛型算法 2009-04-09 17:18 路人

            最后一個(gè)會(huì)改變start哦~~得小心  回復(fù)  更多評(píng)論   


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


            人人狠狠综合久久亚洲婷婷| 久久久久久久精品妇女99| 久久国产色AV免费看| 欧美va久久久噜噜噜久久| 国产成人精品久久二区二区| 久久伊人精品青青草原高清| 久久国产成人亚洲精品影院| 亚洲人AV永久一区二区三区久久 | 99re久久精品国产首页2020| 99久久精品国内| 亚洲欧美日韩久久精品| 久久久国产乱子伦精品作者| 久久人人爽人人爽人人片AV麻豆| 国产精品久久久久久久久久影院| 久久综合给合久久狠狠狠97色69| 国产成人久久777777| 亚洲国产精品无码久久SM| 国产三级观看久久| 久久99精品国产麻豆| 少妇被又大又粗又爽毛片久久黑人 | 久久久久久国产精品无码超碰| 品成人欧美大片久久国产欧美... 品成人欧美大片久久国产欧美 | 日本道色综合久久影院| 91麻豆国产精品91久久久| 99久久无码一区人妻| 国产精品女同久久久久电影院| 久久se精品一区二区影院| 久久精品草草草| 久久ww精品w免费人成| 亚洲精品高清国产一线久久| 久久亚洲av无码精品浪潮| 青青青伊人色综合久久| 精品一区二区久久久久久久网站| 中文字幕乱码久久午夜| 99久久做夜夜爱天天做精品| 久久久人妻精品无码一区| 久久er国产精品免费观看8| 精品久久久久中文字幕一区| 欧美亚洲国产精品久久蜜芽| 久久久久一区二区三区| 99热热久久这里只有精品68|