国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 學(xué)院 > 開發(fā)設(shè)計(jì) > 正文

Bjarne:有了qsort()為何還要sort()?

2019-11-17 05:19:04
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

  對(duì)于初學(xué)者來(lái)說(shuō),

qsort(array,asize,sizeof(elem),elem_compare);
  看上去太古怪了,而且比這個(gè)更難理解:

sort(vec.begin(),vec.end());
  對(duì)于專家來(lái)說(shuō),在元素與比較方式(comparison criteria)都相同的情況下,sort()比qsort()更快,這是很重要的。而且,qsort()是通用的,所以它可以用于不同容器類型、元素類型、比較方式的任意有意義的組合。舉例來(lái)說(shuō):

strUCt Record {
 string name;
 // ...
};

struct name_compare { // 使用"name"作為鍵比較Record
 bool Operator()(const Record& a, const Record& b) const
 { return a.name<b.name; }
};

void f(vector<Record>& vs)
{
 sort(vs.begin(), vs.end(), name_compare());
 // ...
}
  而且,很多人欣賞sort()是因?yàn)樗穷愋桶踩模褂盟恍枰M(jìn)行造型(cast),沒有人必須去為基本類型寫一個(gè)compare()函數(shù)。

  更多的細(xì)節(jié),參見我的文章《將標(biāo)準(zhǔn)C++作為一種新的語(yǔ)言來(lái)學(xué)習(xí)》(Learning C++ as a New language),可以從我的文章列表中找到。

  sort()勝過qsort()的主要原因是,比較操作在內(nèi)聯(lián)(inlines)上做得更好。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 关岭| 乌苏市| 宁阳县| 惠来县| 伽师县| 忻城县| 隆回县| 康乐县| 揭东县| 德格县| 博野县| 岢岚县| 建湖县| 义马市| 明光市| 常宁市| 涡阳县| 彰化市| 宾川县| 营口市| 旬阳县| 茶陵县| 南宫市| 漳州市| 白朗县| 杨浦区| 漯河市| 闵行区| 满城县| 运城市| 隆林| 洛川县| 嘉峪关市| 乐业县| 侯马市| 将乐县| 土默特左旗| 安多县| 绵竹市| 崇阳县| 蒙阴县|