float 和 double 区别 和float面试题

Float 和Double 区别
float是单精度类型,精度是8位有效数字,取值范围是10的-38次方到10的38次方,float占用4个字节的存储空间
double是双精度类型,精度是17位有效数字,取值范围是10的-308次方到10的308次方,double占用8个字节的存储空间
当你不声明的时候,默认小数都用double来表示,所以如果要用float的话,则应该在其后加上f
例如:float a=1.3;
则会提示不能将double转化成float 这成为窄型转化
如果要用float来修饰的话,则应该使用float a=1.3f
注意float是8位有效数字,第7位数字将会产生四舍五入
所以如果一个float变量 这样定义: float a=1.32344435; 则第7位将产生四舍五入(5及5以下的都将舍去)

float 和 double 区别 和float面试题_第1张图片

面试题:

1.java中3*0.1==0.3将会返回什么?true还是false?

fale,因为浮点数不能完全精确的表示出来,一般会损失精度。

2.java中float f = 3.4;是否正确?

不正确,3.4是双精度数,将双精度型(double)赋值给浮点型(float)属于向下转型会造  成精度损失,因此需要强制类型转换float f = (float)3.4;或者写成 float f = 3.4f;才可以。

代码测试
@Test
public void test2() {
float f= 0.3f;
double d = 0.3 * 1;

							System.out.println(f == d);
							System.out.println(d);
							System.out.println(f);
							
				}

float 和 double 区别 和float面试题_第2张图片

你可能感兴趣的:(学习,自己总结)