标签:数据 short round 基础知识 精度 void 范围 超出 ring
类型 | 存储需求 | 取值范围 |
---|---|---|
byte | 1 字节 | -128 ~ 127 |
short | 2 字节 | -32 768 ~ 32 767 |
int | 4 字节 | -2 147 483 647 ~ 2 147 483 647(正好超过20亿) |
long | 8 字节 | -9 223 372 036 854 775 808 ~ 9 223 372 036 854 775 807 |
float | 4 字节 | 大约 ± 3.402 823 47E+38F (有效位数 6 ~ 7 位) |
double | 8 字节 | 大约 ± 1.797 693 134 862 315 70E+308 (有效位数为 15 位) |
在图 3-1 中有 6 个实心箭头,表示无信息丢失的转换;有 3 个虚箭头, 表示可能有精度损失的转换。
当进行二元操作时,先要将两个操作数转化为同一种类型,然后再进行计算。
double
类型, 另一个操作数就会转换为 double
类型。float
类型,另一个操作数将会转换为 float
类型。long
类型, 另一个操作数将会转换为 long
类型。int
类型。/**
* 类型强制转换
* a = 9
* b = 10
*/
private static void typeCast(){
double d = 9.97;
int a = (int)d;
int b = (int)Math.round(d);
//int b = Math.round(d);
System.out.println("a = " + a);
System.out.println("b = " + b);
}
Math.round()
方法对浮点数进行舍人运算, 以便得到最接近的整数Math.round()
方法返回的结果为 long
类型,由于存在信息丢失的可能性,所以只有使用显式的强制类型转换才能够将 long
类型转换成 int
类型。警告:如果试图将一个数值从一种类型强制转换为另一种类型, 而又超出了目标类型的表示范围,结果就会截断成一个完全不同的值。例如,(byte ) 300 的实际值为 44。
--《Java核心技术 卷1 基础知识 原书第10版》P41
/**
* 输出 b = 44
* @param args
*/
public static void main(String[] args){
byte b = (byte)300;
System.out.println("b = " + b);
}
标签:数据 short round 基础知识 精度 void 范围 超出 ring
原文地址:https://www.cnblogs.com/huaranmeng/p/12771054.html