| double类型 | int类型 | 取整说明 |
|---|---|---|
| 123.45 | 123 | 取整后的小数部分被舍弃 |
| -56.78 | -57 | 取整后向负无穷方向舍入 |
| 0.12 | 0 | 取整后的小数部分被舍弃 |
| -0.99 | -1 | 取整后向负无穷方向舍入 |
double变成int时,小数部分会被舍弃。
对于正数,会向0舍入(截断)。
对于负数,会向负无穷方向舍入。
例如:123.45变成int后为123,-56.78变成int后为-57。
专业角度的解释
double类型是64位浮点数,而int类型是32位整数,因此在将double类型转换为int类型时,需要进行取整操作。 取整操作的具体规则如下:
截断:将小数部分直接舍弃,不会四舍五入。
舍入:如果小数部分的数值大于等于0.5,则小数部分进1;否则,小数部分舍去。
向负无穷方向舍入:对于负数,取整后结果总是向负无穷方向舍入,即靠近负无穷。
在实际应用中,将double类型转换为int类型时,需要根据具体业务需求选择是否需要四舍五入。 如果不需要精确度,可以选择截断操作,否则可以选择舍入操作。