java中将一个double类型的数强制转换为long 型是四舍五入吗?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java中将一个double类型的数强制转换为long 型是四舍五入吗?相关的知识,希望对你有一定的参考价值。
Java 中 long 是一个整数基本类型, 长度为64bits, 即8字节.而double存在小数;如果带小数点的double转long型必定会造成数据变化!那么,是怎么变化的呢?
由此可见,java double转long型是取整运算;
参考技术A 不是的,(double) b/1000; 这一步是把b先转化为Double型 然后进行计算
因为计算的类型中有double型 所以1000自动转化为double型
结果就是double型 12.345
b/1000; 这一步是long型/long型 得到的结果也是long型 就是12
然后转化为double型 就是12.0本回答被提问者和网友采纳 参考技术B long是整数类型,转换docuble类型肯定是会把后面的小数给去掉的,是四舍五入的。追问
我试过,不是四舍五入
追答那这个肯定就是直接取整数的了 小数全部舍掉了。长时间不用这个类型。
参考技术C 不是的,直接舍去小数部分。 参考技术D 不是,是直接舍请问double型可以强制转换成int型吗?
double类型可以强制转换成int类型。
可以通过显式强制类型转换、隐式强制类型转换两种方式进行转换。
1、显式强制类型转换
格式为:int b = (int) a;
经强制类型转换运算符运算后,返回一个具有int类型的数值,这种强制类型转换操作并不改变操作数本身,运算后操作数本身未改变。
2、隐式强制类型转换
隐式类型转换发生在赋值表达式和有返回值的函数调用表达式中。在赋值表达式中,如果赋值符左右两侧的操作数类型不同,则将赋值符右边操作数强制转换为赋值符左侧的类型数值后,赋值给赋值符左侧的变量。
在函数调用时,如果return后面表达式的类型与函数返回值类型不同,则在返回值时将return后面表达式的数值强制转换为函数返回值类型后,再将值返回。例如:
int n;double d=3.78;n=d;
执行完后,n的值为3,而d的值仍是3.78。
扩展资料:
自动类型遵循的规则:
1、若参与运算量的类型不同,则先转换成同一类型,然后进行运算。
2、转换按数据长度增加的方向进行,为保证精度不降低。如int型和long型运算时,先把int量转成long型后再进行运算。
3、所有的浮点运算都是以双精度进行的,即使仅含float单精度量运算的表达式,也要先转换成double型,再作运算。
4、char型和short型参与运算时,必须先转换成int型。
5、在赋值运算中,赋值号两边量的数据类型不同时,赋值号右边量的类型将转换为左边量的类型。如果右边量的数据类型长度比左边大时,将丢失一部分数据,这样会降低精度,丢失的部分直接舍去。
参考资料来源:百度百科-强制类型转换
参考技术A double型可以强制转换成int型,即使不加强制转换,也会隐式转换,只是转换结果会丢弃小数部分,如:double d=1.6;
int i;
i=d ; //隐式转换,i结果为1
i=(int)d ; //强制转换,i结果为1
但,如果double变量数据,超过整形数据的表示范围,(一般整数占四个字节,有符号数表示范围为:-2^31 ~ 2^31-1 ),则转换后的结果会是错误的。
以上是关于java中将一个double类型的数强制转换为long 型是四舍五入吗?的主要内容,如果未能解决你的问题,请参考以下文章
JAVA里INT除以INT类型得的结果为FLOAT或者DOUBLE怎样做?