如何确定C++中begin和end运算符返回的迭代器类型?
- 内容介绍
- 文章标签
- 相关推荐
本文共计350个文字,预计阅读时间需要2分钟。
begin和end的返回类型应根据对象是否为常量进行确定。如果对象是常量,则这两个函数应返回const_iterator;如果对象不是常量,则返回iterator类型。下面是一个简化的示例:
cpptemplatetypename enable_if
templatetypename enable_if::typebegin(const T& container) { // 实现逻辑}
begin和end返回的具体类型应该由对象是否是常量进行确定,如果对象是常量,则这两个函数返回const_iterator;
如果对象不是常量,则这个函数返回iterator类型。下面利用一个超级简单的小程序进行验证二者的类型,源代码如下:
#include <iostream> #include <vector> using namespace std; int main() { vector<int> ivec; const vector<int> cv; auto it1 = ivec.begin(); auto it2 = cv.begin(); cout<<typeid(it1).name()<<endl; cout<<typeid(it2).name()<<endl; system("pause"); }
从输出结果,可以很好的验证上面的分析是正确的。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对自由互联的支持。如果你想了解更多相关内容请查看下面相关链接
本文共计350个文字,预计阅读时间需要2分钟。
begin和end的返回类型应根据对象是否为常量进行确定。如果对象是常量,则这两个函数应返回const_iterator;如果对象不是常量,则返回iterator类型。下面是一个简化的示例:
cpptemplatetypename enable_if
templatetypename enable_if::typebegin(const T& container) { // 实现逻辑}
begin和end返回的具体类型应该由对象是否是常量进行确定,如果对象是常量,则这两个函数返回const_iterator;
如果对象不是常量,则这个函数返回iterator类型。下面利用一个超级简单的小程序进行验证二者的类型,源代码如下:
#include <iostream> #include <vector> using namespace std; int main() { vector<int> ivec; const vector<int> cv; auto it1 = ivec.begin(); auto it2 = cv.begin(); cout<<typeid(it1).name()<<endl; cout<<typeid(it2).name()<<endl; system("pause"); }
从输出结果,可以很好的验证上面的分析是正确的。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对自由互联的支持。如果你想了解更多相关内容请查看下面相关链接

