c++ - 当 v 大于 INT_MAX 时,std::distance(v.begin(), v.end()) 的结果是什么?

标签 c++ vector stl iterator integer-overflow

考虑这段代码:

std::vector<char>::size_type size = static_cast<std::vector<char>::size_type>(std::numeric_limits<std::vector<char>::difference_type>::max()) + 1;
std::vector<char> v(size);
std::vector<char>::difference_type diff = std::distance(v.begin(), v.end());

其中 size_typesize_t (unsigned int) 相同,difference_typeptrdiff_t 相同(签名整数)。

如果 vector 的大小大于difference_type的限制,std::distance函数会返回一个负值吗?

最佳答案

对于随机访问迭代器类型,distance(a,b) 被定义为 b-a。随机访问迭代器的减法有一个前提条件:

pre: there exists a value n of type difference_type such that a + n == b.

因此,如果 vector 大小对于 difference_type 而言太大,那么您将打破该先决条件,给出未定义的行为(可能是负面结果;也可能是其他原因)。

关于c++ - 当 v 大于 INT_MAX 时,std::distance(v.begin(), v.end()) 的结果是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26403648/

相关文章:

C++读取文件末尾的剩余数据

c++ - 如何创建类对象的 vector vector

arrays - 从向量的非零值获取相对中间索引

c++ - std::vector 持有基类实例而不是派生类的实例

c++ - 将int的所有字节都设置为(unsigned char)0,保证代表零?

c++ - 错误 : insertor is not a member of std

c++ - 使用 C++ 的 A* 算法求解 n-puzzle

c++ - 由于进程退出期间的静态变量清理,c++ STL 映射中的段错误查找

c++ - 如何复制除一个特定元素外的 vector ?

c++ - 基于 malloc/free 的 STL 分配器