- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
2005中STL使用的一些问题以及标准写法
2005中STL使用的一些问题
在VC6中的STL中Vector的erase函数在2005中有错误,比如下面一段代码:
class A;
extern vectorA vect;
vectorA::iterator it = vect.rbegin();
while(it != vect.rend())
{
if(*it-IsDelete())
{
vect.erase(it)
}
else
{
it++;
}
}
这段代码在VC6中执行是没有问题的,但是在2005中执行就有问题,问题在于stl在执行erase(it)后,会将it的一个数据成员_Mycont(这是一个指向iterator所属vector的的指针)清空。
而在下面的while条件判断it != vect.rend()中,首先会判断it的_Mycont数据成员和vect的指针是否相同,如果不同,则会报错,而执行了erase操作后,就会产生一次清空it的操作,所以在执行的时候就会发生错误了。
在STL中删除一个元素时,有下面二种写法是我们推荐的标准写法:
第一种写法:
it = m_aDibInfos.begin();
for (; it != m_aDibInfos.end();)
{
if (!(*it).bValidFlag)
{
it = m_aDibInfos.erase(it);
}
else
{
it++;
}
}
第二种写法:
bool removeit(int item)
{
if (item % 2 == 1)
{
return true;
}
else
return false;
}
vectorint::iterator deleteit = remove_if(vi.begin(), vi.end(), removeit);
vi.erase(deleteit, vi.end());
在STL的sort函数中,实现的函数只能返回大于的判断,在等于时不能返回真。如下代码在执行时,会有一个Assert错误。请大家注意。
#include stdafx.h
#include iostream
#include vector
#include algorithm
using namespace std;
bool UDgreater ( int elem1, int elem2 )
{
return elem1 = elem2;//如果这样写,执行期报Assert。
}
int _tmain(int argc, _TCHAR* argv[])
{
int a[2]={3,3};
vectorint vi(a, a+2);
cout Original vector v1 endl;
for (vectorint::iterator it = vi.begin(); it != vi.end(); it++)
{
cout*itendl;
}
coutSorted vector v1endl;
sort(vi.begin(), vi.end(), UDgreater);
for (vectorint::iterator it = vi.begin(); it != vi.end(); it++)
{
cout*itendl;
}
getchar();
return 0;
}
可以修改为下面的代码就没有错误了:(
#include stdafx.h
#include iostream
#include vector
#include algorithm
using namespace std;
bool UDgreater ( int elem1, int elem2 )
{
return elem1 elem2;//修改后OK
}
int _tmain(int argc, _TCHAR* argv[])
{
int a[2]={3,3};
vectorint vi(a, a+2);
cout Original vector v1 endl;
for (vectorint::iterator it = vi.begin(); it != vi.end(); it++)
{
cout*itendl;
}
coutSorted vector v1endl;
sort(vi.begin(), vi.end(), UDgreater);
for (vectorint::iterator it = vi.begin(); it != vi.end(); it++)
{
cout*it
您可能关注的文档
最近下载
- 横河涡街流量计第10版DY中文说明书.pdf VIP
- 混凝土挡土墙施工方案..doc VIP
- 六年级梦想之星英语初赛试卷含答案.doc VIP
- 智慧养老机构运营与管理:智慧养老机构健康服务管理PPT教学课件.pptx VIP
- 语文练习部分六年级第一学期(答案).pdf VIP
- 新22G02 钢筋混凝土结构构造 .docx VIP
- 《应急管理》ppt课件.pptx VIP
- 智慧养老机构运营与管理:智慧养老机构生活和快乐服务PPT教学课件.pptx VIP
- 商务部对外贸易司-汽车行业:2022中国二手车出口国别指南.docx VIP
- 智慧养老机构运营与管理:智慧养老机构出入院管理PPT教学课件.pptx VIP
文档评论(0)