强制类型转换取整规则

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录


在主流编程语言(如Java、C/C++、C#等)中,double(或float)强制类型转换为int时,并不是四舍五入,而是直接截断(舍弃)小数部分,遵循**「向零取整」**的规则(即结果向数轴上0的方向取整)。

一、核心行为:截断小数部分(向零取整)

无论小数部分是多少(0.1还是0.9),强制转换时只会保留整数部分,直接丢弃小数位。

1. 正数场景
java 复制代码
// Java示例
double d1 = 3.14;
int i1 = (int) d1; // 结果:3(小数部分0.14被截断)

double d2 = 3.9999;
int i2 = (int) d2; // 结果:3(小数部分0.9999被截断)

double d3 = 5.0;
int i3 = (int) d3; // 结果:5(无小数部分,直接保留)
2. 负数场景

负数的强制转换同样是截断小数部分,向0的方向取整(而非向负无穷取整):

java 复制代码
double d4 = -3.14;
int i4 = (int) d4; // 结果:-3(小数部分0.14被截断)

double d5 = -3.9999;
int i5 = (int) d5; // 结果:-3(小数部分0.9999被截断)

二、如果需要四舍五入,该怎么做?

强制转换的截断行为无法实现四舍五入,需使用语言提供的专用方法:

1. Java

使用Math.round()方法(四舍五入到最近的整数,中间值向正无穷取整):

java 复制代码
double d6 = 3.5;
long l6 = Math.round(d6); // 结果:4(四舍五入)
int i6 = (int) Math.round(d6); // 转int:4

double d7 = -3.5;
long l7 = Math.round(d7); // 结果:-3(中间值向正无穷取整)
int i7 = (int) Math.round(d7); // 转int:-3
2. C/C++

使用<cmath>头文件中的round()函数(需注意返回值是浮点型,需转int):

cpp 复制代码
#include <cmath>
#include <iostream>
using namespace std;

int main() {
    double d = 3.9;
    int i = (int)round(d); // 结果:4(四舍五入)
    cout << i << endl;

    double d2 = -3.9;
    int i2 = (int)round(d2); // 结果:-4(四舍五入)
    cout << i2 << endl;
    return 0;
}

注意:不要用(int)(num + 0.5)的方式(仅对正数有效,负数会出错,比如-3.5 + 0.5 = -3.0,转int是-3,而非四舍五入的-4)。

三、补充:其他取整方式

取整规则 Java方法 C/C++函数 示例(3.9/-3.1)
向零取整(截断) 强制类型转换 强制类型转换 3 / -3
四舍五入 Math.round() round() 4 / -3
向负无穷取整 Math.floor() floor() 3 / -4
向正无穷取整 Math.ceil() ceil() 4 / -3

总结

  • 强制转换doubleint:直接截断小数部分,向零取整,与四舍五入无关;
  • 四舍五入需求 :必须使用语言的专用方法(如Math.round()/round())。
相关推荐
意法半导体STM321 分钟前
【官方原创】STM32H7双核芯片通过 STlink连接失败问题分析 LAT1654
开发语言·前端·javascript·stm32·单片机·嵌入式硬件
深蓝海拓4 分钟前
使用@property将类方法包装为属性
开发语言·python
xiaoye-duck17 分钟前
【C++:unordered_set和unordered_map】 深度解析:使用、差异、性能与场景选择
开发语言·c++·stl
zjjsctcdl33 分钟前
java与mysql连接 使用mysql-connector-java连接msql
java·开发语言·mysql
格林威36 分钟前
Baumer相机锂电池极片裁切毛刺检测:防止内部短路的 5 个核心方法,附 OpenCV+Halcon 实战代码!
开发语言·人工智能·数码相机·opencv·计算机视觉·c#·视觉检测
老约家的可汗39 分钟前
list 容器详解:基本介绍与常见使用
c语言·数据结构·c++·list
顶点多余1 小时前
线程互斥+线程同步+生产消费模型
java·linux·开发语言·c++
Albert Edison1 小时前
【ProtoBuf 语法详解】更新消息|保留字段|未知字段
开发语言·c++·protobuf
feifeigo1231 小时前
近场声全息(NAH)数据与MATLAB实现
开发语言·matlab
fie88891 小时前
基于MATLAB的非线性模型预测控制(NMPC)在CSRT系统中的应用
开发语言·matlab