对于c++整数,1除以2是否可靠地等于0,3/2=1,5/2=2等
With c++ integers, does 1 divided by 2 reliably equal 0, and 3/2 = 1, 5/2 = 2 etc.?
有两个大小不同但相关的向量。较大的是(2 * RESOLUTION) + INDEX_OFFSET
(例如2050(,较小的是简单的RESOLUTION
(例如1024(。我认为假设uint16_t
可以用于包含向量索引是足够安全的。
通过将resultIndex
递增2来执行通过较大向量的迭代。在每次迭代期间,对索引(resultIndex - INDEX_OFFSET) / 2
处的较小矢量进行赋值。
从本质上讲,该代码依赖于这样一个假设,即无论INDEX_OFFSET
是奇数还是偶数,无论架构如何,上述除以2的值都将始终向下取整。例如,如果resultIndex
是0或1,则应为0,如果是2或3,则应是1,依此类推。在上述参数范围内,这是一个安全的假设吗?
注意:我承认存在"除法整数类型-结果是可预测的吗?"但这似乎并不完全匹配。
是;这是由以下语言保证的:
[C++11: 5.6/4]:
二进制/
运算符产生商,二进制%
运算符产生第一个表达式除以第二个表达式的余数。如果/
或%
的第二个操作数为零,则行为未定义对于积分操作数,/
算子产生代数商,丢弃任何小数部分如果商a/b
在结果的类型中是可表示的,则(a/b)*b + a%b
等于a
。
在3/2
中,3
和2
都是整数操作数;这个运算的代数商是1.5
,当你丢弃分数部分.5
时,你得到1
。这适用于你的其他例子,以及所有其他例子。
相关文章:
- 如何反转整数参数包
- enum是C++中的宏变量还是整数变量
- 努力将整数转换为链表。不知道我在这里做错了什么
- 整数不会重复超过随机数
- 在C++中手动调整数组大小
- 检查输入是否不是整数或数字
- C++使用整数的压缩数组初始化对象
- 在C++中,将大的无符号浮点数四舍五入为整数的最佳方法是什么
- 将"打开的CV图像"中的"颜色"转换为整数格式
- 通过套接字[TCP]传输数据 如何在C / C ++中打包多个整数并使用send() recv()传输数据
- 如何只允许用户输入正整数
- 如何在c++中从文本文件中逐行读取整数
- C++:如何循环通过向量中的整数元素
- 我可以信任表示整数的浮点或双精度来保持精度吗
- 序列化,没有库的整数,得到奇怪的结果
- 在一定长度后从数组中打印时缺少整数
- std::当在256字节边界上写入整数时,流的奇怪行为
- 内联程序集printf将整数解释为地址
- 是否基于数组B整数打印数组A中的整数
- 如何在C++中将整数转换为其数字数组