C++中vector的基本问题
在看primer的时候看到vector时,一直看到“指向vector末端之后的下一个元素”这句话怎么理解啊,末端不就是最后一个了么,末端的下一个这个元素根本就不存在啊怎么...
在看primer的时候看到vector时,一直看到“指向vector末端之后的下一个元素”这句话怎么理解啊,末端不就是最后一个了么,末端的下一个这个元素根本就不存在啊怎么指向?难道vector和string一样还默认最后有一个“\0”?
展开
2个回答
展开全部
其实该迭代器是指 指向最后一个元素的下一个“位置”, 而不是下一个元素。
用左闭合区间来理解较为容易:
假设迭代器范围是[1, 5),那么该vector容器有效元素为1, 2, 3和4。
而end迭代器可以理解为指向一个“虚构”的元素5的指针。即最后一个元素4的下一个位置。
用左闭合区间来理解较为容易:
假设迭代器范围是[1, 5),那么该vector容器有效元素为1, 2, 3和4。
而end迭代器可以理解为指向一个“虚构”的元素5的指针。即最后一个元素4的下一个位置。
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2015-06-24
展开全部
就是指该VECTOR对象超出的位置.也是按该VECTOR里的数据类型读取吧.
说白了,已经越界了
C语言也有这回事啊...
#include <stdio.h>
int main()
{
int a[2]={1,2};
printf("%d",a[3]);
return 0;
}
C/C++编译器都不检测是否越界而已
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询