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

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.泛型化元素類型:
用類型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)進(jìn)行比較.另一方面,考慮一下我們以后可能會(huì)用到來(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)的指針,該指針要指向要查找的數(shù)據(jù)的開(kāi)頭.但是如果仔細(xì)分析一下,會(huì)發(fā)現(xiàn)我們只依賴于指針的某些保留特性:
1)可以把指針當(dāng)參數(shù)接收,并把它們作為結(jié)果返回.
2)可以比較指針是否相等.
3)可以解除引用,以便得到值:*p.
4)可以遞增,以指向下一個(gè)元素.
 
只要符合上述條件的類型即可,不一定是指針類型.假設(shè)把T*作為模板參數(shù),我們就取消了對(duì)指針的依賴:
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)于具體類型的信息.根本沒(méi)有要求p是指針,只要求p滿足上述的四個(gè)特性.
 

 

posted on 2009-03-06 17:43 martin_yahoo 閱讀(1814) 評(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è)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲欧美成人一区二区三区| 99国内精品久久| 性欧美办公室18xxxxhd| 日韩亚洲不卡在线| 欧美片在线播放| 99精品视频一区| 亚洲视频在线观看一区| 国产日韩欧美中文| 久久亚洲综合| 欧美激情精品久久久六区热门| 国产精品久久久久久久久久妞妞 | 国产精品一卡| 久久狠狠一本精品综合网| 久久国产主播精品| 在线日韩av片| 久久五月婷婷丁香社区| 欧美插天视频在线播放| 亚洲午夜影视影院在线观看| 午夜电影亚洲| 亚洲免费观看在线观看| 亚洲免费一在线| 亚洲国语精品自产拍在线观看| 日韩午夜免费| 国内在线观看一区二区三区| 91久久国产综合久久| 欧美美女视频| 久久九九免费视频| 欧美日韩伦理在线| 美女脱光内衣内裤视频久久影院 | 亚洲国产欧美一区二区三区久久| 亚洲精品网址在线观看| 国内精品久久久久影院优| 亚洲第一网站免费视频| 国产日韩一区二区三区在线| 亚洲国产日韩欧美一区二区三区| 国产精自产拍久久久久久| 亚洲国产成人在线播放| 国产一区二区毛片| 在线亚洲观看| 999在线观看精品免费不卡网站| 欧美一区二区免费| 亚洲男同1069视频| 欧美日产在线观看| 欧美成人亚洲| 国内精品视频在线观看| 亚洲午夜成aⅴ人片| 99精品久久久| 欧美成人一区二区三区| 欧美国产一区在线| 国产欧美日韩精品一区| 中文国产成人精品| 一区二区三区精品| 欧美精品大片| 91久久精品久久国产性色也91 | 欧美女同在线视频| 欧美高清免费| 久久不射中文字幕| 国产精品久久久久久久久久直播| 亚洲黄网站黄| 最近中文字幕日韩精品| 老鸭窝毛片一区二区三区| 久久亚洲精品视频| 黄色成人在线| 噜噜噜久久亚洲精品国产品小说| 久久人体大胆视频| 亚洲女优在线| 欧美一区二粉嫩精品国产一线天| 欧美日韩少妇| 在线一区日本视频| 亚洲夜间福利| 国产精品稀缺呦系列在线| 亚洲综合久久久久| 欧美亚洲一区二区在线| 国产精品在线看| 久久精品国内一区二区三区| 老司机aⅴ在线精品导航| **性色生活片久久毛片| 欧美国产日产韩国视频| 日韩一级精品| 久久av免费一区| 国产综合激情| 美女黄毛**国产精品啪啪| 91久久黄色| 亚洲免费视频成人| 国产一区二区三区久久悠悠色av | 亚洲美女视频在线观看| 亚洲一二三区在线观看| aa级大片欧美三级| 欧美一区二区国产| 亚洲高清精品中出| 欧美日韩视频在线一区二区观看视频 | 久久精品免费看| avtt综合网| 国产精品久久久久久久久搜平片 | 一本色道久久综合亚洲精品婷婷| 欧美日韩一本到| 欧美一区二区三区四区夜夜大片| 久久综合色播五月| 亚洲图片欧美午夜| 国内成人精品一区| 欧美日本二区| 亚洲欧美在线网| 欧美黄色一区| 欧美一级视频精品观看| 在线观看视频亚洲| 国产精品国产成人国产三级| 亚洲欧洲久久| 久久久亚洲高清| 亚洲最新色图| 女主播福利一区| 亚洲欧美中日韩| 日韩一级在线观看| 韩日精品中文字幕| 国产一二精品视频| 久久一区亚洲| 亚洲在线中文字幕| 亚洲精品久久久蜜桃| 久久夜色精品国产噜噜av| 亚洲视频图片小说| 亚洲精品视频一区二区三区| 国产人成精品一区二区三| 欧美日韩国语| 欧美韩国一区| 免费观看成人鲁鲁鲁鲁鲁视频 | 欧美成熟视频| 久久福利电影| 亚洲欧美一级二级三级| 99热在这里有精品免费| 亚洲国产成人久久| 激情六月婷婷久久| 国产精品黄色在线观看| 欧美日韩视频在线观看一区二区三区 | 亚洲欧美日韩国产一区| 香蕉乱码成人久久天堂爱免费| 亚洲成色777777女色窝| 日韩亚洲欧美成人| 亚洲性夜色噜噜噜7777| 亚洲精品乱码久久久久久蜜桃91| 快播亚洲色图| 你懂的国产精品永久在线| 久久精品99国产精品酒店日本| 午夜免费日韩视频| 欧美激情第一页xxx| 亚洲免费在线播放| 午夜精品在线| 欧美专区第一页| 欧美在线视频全部完| 欧美呦呦网站| 久久人人爽人人| 欧美99久久| 亚洲国内在线| 日韩一级免费| 亚洲欧美中文日韩v在线观看| 亚洲欧美成人一区二区三区| 亚洲永久免费| 久久大逼视频| 久久综合中文字幕| 免费人成网站在线观看欧美高清| 欧美成人免费视频| 欧美日韩午夜| 国产色产综合色产在线视频| 韩国精品在线观看| 最新高清无码专区| 亚洲一区国产视频| 久久九九热re6这里有精品| 久久天天躁狠狠躁夜夜爽蜜月| 欧美99久久| 亚洲一区3d动漫同人无遮挡| 欧美一区影院| 欧美激情无毛| 国产精品自拍在线| 最新精品在线| 久久国产一区二区三区| 欧美高清自拍一区| 一区二区三区高清视频在线观看 | 亚洲精品美女91| 亚洲在线观看| 欧美成va人片在线观看| 国产精品99久久久久久有的能看| 欧美影视一区| 欧美日韩综合精品| 激情久久中文字幕| 亚洲综合第一页| 欧美成人精品福利| 国产亚洲精品久久久久久| 欧美大片网址| 国产一区二区三区精品久久久| 亚洲精品乱码久久久久久日本蜜臀 | 亚洲经典自拍| 亚洲免费中文| 国产亚洲第一区| 久久久精品一区| 一级日韩一区在线观看| 国产精品伦理| 免费在线日韩av| 午夜免费日韩视频| 一区二区三区www| 欧美一区日韩一区| 欧美mv日韩mv国产网站| 久久免费视频网站|