今天写代码的时候,发现了一个错误,源代码如下
for(unsigned i = 0;i!=s.size();++i)
{
cout << s.size() <<endl;
if(s[i] >= 'A' && s[i] <= 'Z')
{
s[i] -= ('A' - 'a');
}
else if(s[i] == '.' )
{
s.erase(i,1);
}
}
在循环中,我用不等于来限定循环的范围,结果运行的时候出错,强制关闭,调试过程中,发现,i的值跳变到了size之外。
576已经远大于size的值,所以程序进入了死循环,这就是“!=”的缺陷,当循环值跳出范围之外,循环程序无法检测出来,但是《c++ primer》中介绍,对于迭代器的循环操作,使用“!=”要比“<”更合适,这也是由迭代器的特性决定的,泛型算法的一些操作会使迭代器失效,但是迭代器和end()的关系可以用“!=”清晰表示,所以,在循环中,应该区别对待,涉及迭代器的循环操作用“!=”,对于普通情况,使用“<”逻辑上更保险。