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

            常用鏈接

            統計

            software

            最新評論

            模板與泛型算法

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

             

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

            評論

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

            cool  回復  更多評論   

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

            mark  回復  更多評論   

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

            最后一個會改變start哦~~得小心  回復  更多評論   

            久久亚洲熟女cc98cm| 性做久久久久久免费观看| 99久久香蕉国产线看观香| 欧美亚洲国产精品久久高清| 久久久久久国产精品无码超碰 | 国产精品欧美亚洲韩国日本久久| 精品人妻伦九区久久AAA片69| 久久久久青草线蕉综合超碰| 狠狠色噜噜狠狠狠狠狠色综合久久| 久久久久久国产精品无码下载| 久久综合狠狠综合久久综合88| 久久久精品人妻无码专区不卡 | 99久久精品免费观看国产| 久久综合久久美利坚合众国| 99久久这里只有精品| 一本一本久久a久久综合精品蜜桃| 久久99国产精一区二区三区| 久久久精品国产sm调教网站| 色悠久久久久久久综合网| 99久久99久久精品国产片| 久久人人妻人人爽人人爽| 亚洲国产成人精品女人久久久| 99久久国产免费福利| 色综合久久中文色婷婷| 久久发布国产伦子伦精品| 精品熟女少妇AV免费久久| 久久综合亚洲色一区二区三区| 四虎久久影院| 无码乱码观看精品久久| 四虎久久影院| 一级A毛片免费观看久久精品| 国产亚洲成人久久| 久久久久女教师免费一区| 久久久精品波多野结衣| 一本综合久久国产二区| 亚洲欧美久久久久9999| 国产成人综合久久精品红| 久久久久亚洲AV片无码下载蜜桃| 亚洲精品乱码久久久久久蜜桃不卡| 亚洲欧美日韩久久精品第一区| 亚洲精品无码久久千人斩|