C++迭代器有多聪明
How smart is C++ deque iterator
假设我有一个包含 100 个值的std::deque<int> d
,从 0
到 99
。鉴于以下情况:
与向量不同,deques不能保证将其所有元素存储在 连续存储位置:访问双端面元素 偏移指向另一个元素的指针会导致未定义的行为。
下面一行似乎无效:
int invalidResult = *(d.begin() + 81); // might give me 81, but NOT GUARANTEED, right?
我的问题是:迭代器会处理这个问题吗?
std::deque<int>::iterator it = d.begin();
int isThisValid = *(it + 81); // 81 every time? or does it result in undefined behavior?
有一次,我以为迭代器会处理底层存储中的任何不连续性,但现在我不太确定。显然,如果你使用it++
81次,*it
会给你带来81
结果。
有人可以肯定地说吗?
对于它的价值,我不使用 C++11。
下面一行似乎无效:
int invalidResult = *(d.begin() + 81); // might give me 81, but NOT GUARANTEED, right?
相反。该语句是完全有效的,并且行为是有保证的(假设d.size() >= 82
)。这是因为std::deque::begin
返回的是迭代器,而不是指针,因此引用的规则不适用。
std::deque<int>::iterator it = d.begin(); int isThisValid = *(it + 81); // 81 every time? or does it result in undefined behavior?
这几乎等同于前面的代码,只是您使用了命名变量,而不是临时迭代器。行为完全相同。
<小时 />以下是您不能执行的操作的示例:
int* pointer = &d.front();
pointer[offset] = 42; // oops
根据这里的参考,std::d eque 提供了一个 RandomAccessIterator,它肯定会根据您的示例工作。
std::deque<int>::iterator it = d.begin();
int isThisValid = *(it + 81); // will be fine assuming the deque is that large
相关文章:
- 使用std::multimap迭代器创建std::list
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- C++中带有List类的迭代器Segfault
- 如何在c++迭代器类型中包装std::chrono
- 集合上的输出迭代器:assign和increment迭代器
- Boost Spirit,获取迭代器内部语义动作
- 对于set上的循环-获取next元素迭代器
- 为什么output_editor Concept不需要output_e迭代器标记
- c++17文件系统::recursive_directory迭代器()在mac上没有给出这样的目录,但在windows上
- 使用迭代器时如何访问对象在向量中的位置?
- std::vector::迭代器是否可以合法地作为指针
- 跟随整数索引列表的自定义类迭代器
- 不明白迭代器,引用和指针失效,一个例子
- 我可以使用反向迭代器作为ForwardIt吗
- ESP8266单片机矢量迭代器的C++问题
- 如何在C++中将迭代器作为函数参数传递
- 是否应避免从非常量迭代器转换为常量迭代器?
- 如何在 c++ 中将字符串迭代器变量传递给函数?
- 为什么 vector 的随机访问迭代器给出与指针不同的内存地址?
- 为什么 C++ std::unordered_map 从 emplace/ 找到返回一个迭代器?