为什么定义long类型跟float类型的变量时要加l和f

java的内存体制

long fw =  10000000000L;
实际上内存中fw只是一个long类型的变量,它存在于向stack(栈)中,数值并不在其中存放,它指向heap(堆)中另一块真正存放数值的内存,加L的目的就是为了让heap中也创建一块long类型所需要的内存,用来来放数值。

所以说=前后两者其实是在不同的两块内存,只不过有个无形的指针将两者连接起来了。

问:

整数的默认的数据类型是int,那为什么byte和short类型后面不用加东西?

答:

java整型默认为int,且java会自动向下转型,byte和short都可以由int自动向下转型,但是long类型的不能自动向上转型,所以要加L,转为long类型

不加的后果:

不加L默认是int,int转为long是安全的,所以会自动转,能编译通过
浮点数不加F默认是double类型,double转float可能损失精度,因为不会自动转,编译通不过
如果超过int的取值范围还不加L,那么也会直接报错了

你可能感兴趣的:(为什么定义long类型跟float类型的变量时要加l和f)