浅谈Java数值类型的转换与强制转换
作者:Clearlight™ 发布时间:2022-07-01 15:24:00
数值类型之间的转换
6个实心箭头箭头表示无信息丢失的转换;
3个虚箭头表示可能有精度损失的转换.
当使用上面两个数值进行二元操作时,先要将两个操作数转换为同一类型,然后再进行计算.
规则:`两个数中小类型的值将自动转换为大类型的值.
小转大可以,但是大转小会损失精度,则需要强制转换.
强制类型转换
语法格式
在圆括号中给出想要转换的目标类型,后面紧跟待转换的变量名.
例:
double m = 9.99;
int n = (int)m;
其中n的值为9.
强制类型转换通过截断小数部分将浮点值转换为整形.
Math.Round()
返回最接近参数的 int。结果将舍入为整数:加上 1/2,对结果调用 floor 并将所得结果强制转换为 int 类型。换句话说,结果等于以下表达式的值:
(int)Math.floor(a + 0.5f)
特殊情况如下:
如果参数为 NaN,那么结果为 0。
如果结果为负无穷大或任何小于等于 Integer.MIN_VALUE 的值,那么结果等于 Integer.MIN_VALUE 的值。
如果参数为正无穷大或任何大于等于 Integer.MAX_VALUE 的值,那么结果等于 Integer.MAX_VALUE 的值。
public static int round(float a) :
若传入Round方法的值为float,返回值为int,可直接用int类型的值接收即可.
public static long round(double a) :
但传入Round方法的值为double时,返回值为long,则需要手动强转为int类型.
代码示例:
public class MathRoundDemo {
public static void main(String[] args) {
double a = 1.847;
System.out.println(Math.round(a));
float b = 1.847f;
System.out.println(Math.round(b));
int c = (int)Math.round(a);
System.out.println(c);
System.out.println(Math.round(a*100)/100.0);
System.out.printf("%.2f",a);
}
}
/*输出:
2
2
2
1.85
1.85
*/
代码分析:
float b = 1.847f;若不添加后缀f,则需要将1.847进行强转,默认小数位double类型.赋给float(大转小会损失精度,则需要强制转换).
int c = (int)Math.round(a);传入的参数为double类型,返回类型为long,同理,大转小,需要强制转换.
对于想要进行小数位数的保留方法,此代码中想要1.847保留小数点后两位:
System.out.println(Math.round(a*100)/100.0);
原理:小数点先右移两位后应用Math.round方法进行四舍五入后,在将小数点向左移两位.
System.out.printf("%.2f",a);
原理:应用了格式化输出,推荐使用这种方式简单高效稳定.具体介绍请看:Java中格式化输出
以上所述是小编给大家介绍的Java数值类型的转换与强制转换详解整合网站的支持!
来源:https://blog.csdn.net/qq_36852780/article/details/89048556#_3


猜你喜欢
- 1、确定本地网络是通的:2、确定SpringBootq启动后是不报错的3、查看是不是自己在配置文件中加入了项目路径:如果加入了项目路径的话,
- 本文参考文档Add Flutter to existing apps。首先有一个可以运行的原生项目第一步:新建Flutter moduleT
- 面向对象的程序是由对象组成的,每个对象包含对用户公开的特定功能部分和隐藏的实现部分。在面向对象程序设计(OOP)中,不必关心对象的具体实现。
- Eureka大白话解析笔记补录:1.Eureka 介绍Spring Cloud Eureka 是 Spring Clou
- Elastic Search是一个开源的,分布式,实时搜索和分析引擎。Spring Boot为Elasticsearch及Spring Da
- 前言菱形继承是多重继承中跑不掉的,Java拿掉了多重继承,辅之以接口。C++中虽然没有明确说明接口这种东西,但是只有纯虚函数的类可以看作Ja
- 最近看代码,由于代码的调用层级深度比较多,层层深入到某处时,已经忘记了身处何处,虽然自己可以使用一些画图工具来时序图,但是,这种情况下,自己
- 多态概述多态概念:所谓多态就是指程序中定义的引用变量所指向的具体类型和通过该引用变量发出的方法调用在编程时并不确定,而是在程序运行期间才确定
- 在处理网络请求时,有一部分功能是需要抽出来统一处理的,与业务隔开。登录校验可以利用spring mvc的 * Interceptor,实现H
- SpringBoot如何快速配置数据源;有如下两种方式:通过spring-boot-starter-jdbc快速配置数据源自定义数据源Dat
- 最近在用ssm框架做一个管理系统,做到登录验证时,使用了下面的代码生成图片验证码,最终的效果如下图。Java类public class Ra
- 本文实例为大家分享了java实现图片分割指定大小的具体代码,供大家参考,具体内容如下1.使用工具:ThumbnailsThumbnails
- tcp一般用于维持一个可信任的连接,比起udp更为安全可靠,在vs.net,分别有tcpclient和udpclient以及tcpliste
- 一、实现流程1.注册2.登录3.登录保持【状态续签】二、实现方法项目结构1.引入依赖<!-- spring-web --><
- 1. 参数中直接加入%%param.setUsername("%CD%"); param.set
- 前言算法对于程序员的重要性不言而喻,今天我和大家分享算法中的一个基础算法,快速排序。作为一名程序员,相信大家都不陌生,但是要大家徒手一次性写
- C++编写的一个图书管理系统,供大家参考,具体内容如下2018大一的课设,搬到这纪念一下,共1200多行代码为图书管理人员编写一个图书管理系
- 获取缓存大小接口主要这里的方法已经和7.0不兼容了。import android.app.usage.UsageStats;import a
- 延迟加载(lazy loading) 设计模式是为了避免一些无谓的性能开销而提出来的,所谓延迟加载就是当在真正需要数据(读取属性值)的时候,
- 我们都知道现在的语音合成TTS是可以通过微软的SAPI实现的,好处我就不多说了,方便而已,因为在微软的操作系统里面就自带了这个玩意,主要的方