WEB开发网      濠电娀娼ч崐濠氬疾椤愶附鍋熸い鏍ㄧ〒闂勫嫰鏌﹀Ο渚Ц闁诲氦顕ч湁婵犲﹤楠告禍鍓х磼鏉堛劌绗氶柟宄版嚇閹晠宕归銈嗘濠电偞鍨堕幐鎾磻閹捐秮褰掓偐閻戞﹩妫勯梺鎼炲妼鐎涒晝绮嬪澶樻晝闁挎繂鏌婇敃鍌涚厵閻庢稒锚閻忥絾绻濇繝鍐ㄧ伌闁诡垰鍟村畷鐔碱敂閸♀晙绱樺┑鐐差嚟婵儳螞閸曨剚鍙忛柍鍝勬噹缁€澶嬬箾閹存繄锛嶆鐐灲閹綊宕惰濡插鏌涢妸銉ヮ劉缂佸倸绉归弫鎾绘晸閿燂拷 ---闂備焦瀵уú鈺呭箯閿燂拷
开发学院软件开发C++ C++通用删除器设计 阅读

C++通用删除器设计

 2010-11-17 12:12:20 来源:WEB开发网 闂備線娼уΛ鎾箯閿燂拷闂備礁鎲¢崹鐢垫崲閹扮増鍎嶆い鎺戝€甸崑鎾斥槈濞嗗秳娌紓鍌氱▌閹凤拷濠电姭鎷冮崨顓濈捕闂侀潧娲ゅú銊╁焵椤掍胶鈯曢柕鍥╁仧缁辩偤鏁撻敓锟�闂備線娼уΛ鎾箯閿燂拷  闂備胶枪缁绘鈻嶉弴銏犳瀬闁绘劕鐏氱€氼剟姊洪崹顕呭剰闁逞屽墮缁夊綊寮婚妸褉鍋撻棃娑欏暈闁伙綀浜埀顒傛暬閸嬪﹪宕伴弽褏鏆﹂柨鐕傛嫹
核心提示:第二部分比较有意思:它是一个仿函数,它可以在一定程度上代替delete_null(first,last),C++通用删除器设计(2),以下代码展示了分别使用这两种方式回收容器中的堆对象的方法:typedefstd::vector<Text*>TextPack;TextPackuTexts1,uTexts2;

第二部分比较有意思:它是一个仿函数。它可以在一定程度上代替delete_null(first,last),以下代码展示了分别使用这两种方式回收容器中的堆对象的方法:

typedefstd::vector<Text*>TextPack;
TextPackuTexts1,uTexts2;
constintdatasize=100;
for(inti=0; i<datasize;++i)
{
uTexts1.push_back(newText);
uTexts2.push_back(newText);
}

//使用delete_null
delete_null(uTexts1.begin(),uTexts1.end());
//使用deleter
std::for_each(uTexts2.begin(),uTexts2.end(),deleter());

可以看到前者稍微简洁一些(包括最终的汇编代码),那么问题来了:为什么还需要代码量更大一些的deleter仿函数?

理由是:并不是所有存储堆对象的集合都是直接存储对象指针的。比如可以将指针存储在std::map中“值”部分,甚至有些自定义集合只提供了遍历函数(类似于std::for_each),但并不公开迭代器接口。在这些情况下,我们就可以使用deleter仿函数进行堆对象回收。

上一页  1 2 

Tags:C++ 删除器 设计

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接