- 前置++表示先对对象加1,然后返回加1后的值
- 后置++表示先对对象的运算之前的值的副本保存下来,然后对对象加1,然后返回对象运算之前的副本
- 以上两点可以看出前置++返回的是对象本身,它是一个左值,后置版本返回的是副本它是一个临时量,它是一个右值,因此可以对前置++的结果进行改变,而不可以对后置++的结果进行改变(左值可以改变,可以取地址,右值不可以)
- 后置++通常运用到容器中,以防访问到不可访问的值
1 //输出vector对象知道遇到第一个负值 2 auto pbeg=v.begin(); 3 while(pbeg!=v.end()&&*pbeg>=0) 4 cout<<*pbeg++<<endl;//假定没有负值,pbeg++后已经指向尾后元素但是解引用的是最后一个元素
下面给出一段问题代码:
1 for(auto iter=mapTest.begin();iter!=mapTest.end();++iter)//或则iter++ 2 { 3 cout<<iter->first<<":"<<iter->second<<endl; 4 mapTest.erase(iter); 5 }
问题在于,容器不可以使用已经删除的元素对应的迭代器,上例中本次循环使用了迭代器删除了其对应的元素,接着对这个删除了的元素的迭代器进行++操作进入了下一次的循环。
解决方法是边删除边后置++
1 for(auto iter=mapTest.begin();iter!=mapTest.end();) //注意此处不能再写iter++ 2 { 3 cout<<iter->first<<":"<<iter->second<<endl; 4 mapTest.erase(iter++); //先将iter运算之前的值的副本保存下来,然后对iter加1,最后将iter运算之前的值返回给函数,实现对迭代器对应位置删除的操作 5 }
参考文章
c++:map容器中erase()的坑_c++ map erase_网格小生的博客-CSDN博客