计算两个 std::reverse_iterators 之间的 std::d stance
calculate std::distance between two std::reverse_iterators
我有这样的代码片段:
int* array = new int[size];
std::reverse_iterator<int*> it2 = ... // arbitrary in array
如何计算最后一个和it2
之间的距离?我试过这个,但它返回零:
std::distance(std::reverse_iterator<int*>(array + size), it2);
你计算距离的方法在我看来是正确的。当然,当使用 gcc 或 clang 时,这会打印10
:
#include <algorithm>
#include <iostream>
#include <iterator>
int main()
{
const int size = 20;
int* array = new int[size];
std::cout << "distance="
<< std::distance(std::reverse_iterator<int*>(array + 20),
std::reverse_iterator<int*>(array + 10))
<< 'n';
delete[] array;
}
相关文章:
- 使用std::multimap迭代器创建std::list
- C++中std::resize(n)和std::shrink_to_fit之间的区别
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- C++17复制构造函数,在std::unordereded_map上进行深度复制
- 如何导出包含具有"std::unique_ptr"值的"std::map"属性的
- 从持续时间构造std::chrono::system_clock::time_point
- std::具有相同基类的类的变体
- std::向量与传递值的动态数组
- 使用std::vector的OpenCL矩阵乘法
- std::map<struct,struct>::find 找不到匹配项,但是如果我循环通过 begin() 到 end(),我在那里看到匹配项
- std::condition_variable::wait()如何评估给定的谓词
- 如何获取std::result_of函数的返回类型
- std::原子加载和存储都需要吗
- 将对象移动到std::shared_ptr
- POCO::PostgreSQL:如何将std::vector支持添加到`Binder::bind`
- std::copy with return values - 防止"expression: string iterators incompatible"的更好方法?
- std::d eque : "insertion and deletion of elements may invalidate iterators"是什么意思?
- VS2010: assert "vector iterators incompatible" in std::vector.clear()
- std::map with iterators to std::list from iterators of std::
- Transform_iterator与std::iterators不兼容