目录
一、浮点型变量
-
双精度浮点型
public static void main(String[] args) {
double a=1.01;
System.out.println(a);//输出为1.01
}
例一:当求小数时,用整形int能否求出呢:
public static void main(String[] args) {
int a=1;
int b=2;
System.out.println(a/b);
}
编译程序:
如上图所示,我们不能得到想要的1/2=0.5,得到的结果为0,说明是不能用整型求浮点数 ,因为在java中,int除以int的值仍然是int,会直接舍弃掉小数部分,所以要求得0.5,只能用double定义
public static void main(String[] args) {
double a=1.0;
double b=2.0;
System.out.println(a/b);
}
编译程序发现结果是我们想要的结果
除了这个例题之外,还有一个有趣的题
public static void main(String[] args) {
double a=0.5;
double b=1.1;
System.out.println(a*a);
System.out.println(b*b);
}
进行编译:
如图,我们发现了一个神奇的现象,发现0.5*0.5得到的结果是0.25,而1.1*1.1却不是我们以为的1.21,这是因为double类型的内存布局遵守IEEE 754标准,尝试使用有限的内存空间表示更多可能无限的小数,那么就会存在一定的精度误差,故而浮点数是一个近似值,并不是精确值。
注意:
- double在任何系统下都是8个字节
- double的包装类型为Double
- 浮点数与整数在内存中的存储方式不同,不能单纯使用n^2的形式来计算
- double类型的内存布局遵守IEEE 754标准,尝试使用有限的内存空间表示更多可能无限的小数,那么就会存在一定的精度误差,故而浮点数是一个近似值,并不是精确值。
-
单精度浮点型
float类型在java中占4个字节,同样遵守IEEE 754标准。但是float表示的数据精度范围较小,一般在工程上优先考虑double,不推荐float。float的包装类型为Float
public static void main(String[] args) {
float a=1.0f;
float b=1.0F;
System.out.println(a);
System.out.println(b);
}
进行编译
如上图,说明1.0f与1.0F效果是一样的。
普及:
- IEEE二进制浮点数算术标准(IEEE 754)是20世纪80年代以来最广泛使用的浮点数运算标准,为许多CPU与浮点运算器所采用。这个标准定义了表示浮点数的格式(包括负零-0)与反常值(denormal number)),一些特殊数值(无穷(Inf)与非数值(NaN)),以及这些数值的“浮点数运算符”;它也指明了四种数值舍入规则和五种例外状况(包括例外发生的时机与处理方式)。
- IEEE 754规定了四种表示浮点数值的方式:单精确度(32位)、双精确度(64位)、延伸单精确度(43比特以上,很少使用)与延伸双精确度(79比特以上,通常以80位实现)。 只有32位模式有强制要求,其他都是选择性的。
- 大部分编程语言都有提供IEEE浮点数格式与算术,但有些将其列为非必需的。例如,IEEE 754问世之前就有的C语言,有包括IEEE算术,但不算作强制要求(C语言的float通常是指IEEE单精确度,而double是指双精确度)。
- 该标准的全称为IEEE二进制浮点数算术标准(ANSI/IEEE Std 754-1985),又称IEC 60559:1989,微处理器系统的二进制浮点数算术(本来的编号是IEC 559:1989)。 后来还有“与基数无关的浮点数”的“IEEE 854-1987标准”,有规定基数为2跟10的状况。最新标准是“ISO/IEC/IEEE FDIS 60559:2010”。
二、字符型变量
语法表示:用单引号+单个字母表示
计算机中的字符本质上是一个整数,在C语言中使用ASCLL表示字符,在java中使用Unicode表示字符,故而一个字符占用两个字节,表示的字符种类更多,包括中文。
char的包装类型为Character
public static void main(String[] args) {
char a='A';//大写字符
char b='1';//数学字符
System.out.println(a);
System.out.println(b);
//注意:java中的字符可以存放整形
char c='整';
System.out.println(c);
}
进行编译:
-
三、布尔型变量
布尔型变量常常用来表示真假,但是boolean类型的变量只有两种取值:true表示真,false表示假
public static void main(String[] args) {
boolean a=true;
System.out.println(a);
boolean b=false;
System.out.println(b);
}
进行编译:
到这里,思考一个问题:java中的boolean类型和int类型能否相互转换呢?
//假设boolean和int可以相互转换
public static void main(String[] args) {
boolean a=true;
System.out.println(a+1);
}
我们对其编译,发现
出现了错误:java: 二元运算符 '+' 的操作数类型错误
第一个类型: boolean
第二个类型: int
说明boolean类型与int类型之间是不能相互转换的,也就是不存在1表示true,0表示false这样的用法
注意:
- boolean类型的变量只有两种取值:true表示真,false表示假
- boolean类型与int类型之间是不能相互转换的,不存在1表示true,0表示false这样的用法
- java虚拟机规范中,没有明确规定boolean占几个字节,没有大小,没有专门用来处理boolean的字节码指令,而在Oracle公司的虚拟机实现中,boolean占1个字节
- boolean的包装类型是Boolean
本文的知识暂时到这里,主要介绍了 浮点型变量、字符型变量、布尔型变量,当然,介绍的都是最基础的,如果有什么问题,望各位大佬们指点!