c++ - 为什么双端队列的大小会小于一个小数?

标签 c++ while-loop deque

我有一个程序,我需要在其中制作一个足够长的 deque 以在特定索引处保存一个项目。我使用以下循环来扩展 deque:

while(int1+deque1.size()<=int2){
     deque1.push_back(0);
}

int1int2 都是 -1 时(以及在许多其他情况下;这是我在调试时注意到的),deque1 增长到一个巨大的规模(数十万个项目),但循环仍在继续。这是为什么?

最佳答案

deque::size() 返回一个 unsigned long int,因此 int1 和 int2 必须是正数,否则会溢出。

这是编译器自动生成的代码。

while(static_cast<unsigned long>(int1)+deque1.size()<=static_cast<unsigned long>(int2)){
 deque1.push_back(0);
}

因此,如果(例如)int1 是一个 8 位无符号整数,并且您给它赋值 -1,它将变为 (2^8 - 1 = 255)。这就是位编码在计算机中的工作方式。

解决方案大概是这样的:

while(int1+static_cast<ptrdiff_t>(deque1.size())<=int2){
 deque1.push_back(0);
}

干杯。

关于c++ - 为什么双端队列的大小会小于一个小数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15855106/

相关文章:

c++ - 引用指针的内存泄漏

sql - 避免 SQL Server 中的 while 循环

javascript - while 条件中的赋值表达式是一种不好的做法?

c++ - 警告 "C++ requires a type specifier for all declaration"图

c++ - 哪个编译器符合标准?

c++ - 将类成员函数绑定(bind)到 c 函数

c++ - 合并排序无法在流程结束时合并零件

javascript - 如何每 5 个值插入一个换行符?

c++ - 如何在不进行类型转换的情况下从双端队列中提取?

c++ - 使用类对象对双端队列进行排序