强制类型转换取整规则

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

文章目录


在主流编程语言(如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())。
相关推荐
㓗冽4 分钟前
60题之内难题分析
开发语言·c++·算法
dingdingfish12 分钟前
Bash学习 - 第3章:Basic Shell Features,第5节:Shell Expansions
开发语言·学习·bash
rainbow688913 分钟前
C++开源库dxflib解析DXF文件实战
开发语言·c++·开源
deepxuan14 分钟前
Day7--python
开发语言·python
John_ToDebug17 分钟前
Chromium安全架构深度解析:从悬空指针检测到内存安全防御体系
c++·chrome
D_evil__24 分钟前
【Effective Modern C++】第五章 右值引用、移动语义和完美转发:24. 区分万能引用和右值引用
c++
禹凕29 分钟前
Python编程——进阶知识(多线程)
开发语言·爬虫·python
蜡笔小马42 分钟前
10.Boost.Geometry R-tree 空间索引详解
开发语言·c++·算法·r-tree
IOsetting42 分钟前
金山云主机添加开机路由
运维·服务器·开发语言·网络·php
林开落L1 小时前
从零开始学习Protobuf(C++实战版)
开发语言·c++·学习·protobuffer·结构化数据序列化机制