java栈中基本类型的内存分配原则以及比较

原创
2016/09/11 17:35
阅读数 94

        大家都知道引用类型,栈中只存在着引用的地址,那么普通类型呢。这里先举个例子展示结果。都是问栈中有多少数字的问题。

int a =10;
int b=10;

        这种情况,栈里只有一个1个数字。

int a =10;
int b=11;

        这种情况有两个数字。

int a =10;
int b=10;
int c=11;

        这种情况有两个数字。

        栈中有多少个数字和变量的个数没有直接关系,在相同的生命周期内,栈会共享数据。int a=10,此时栈里没有数字10,他就会分配空间,创建一个10,然后a指向10的地址,int b=10,此时栈会发现有10,然后b也指向10,如果接下来b=11,栈发现没有11这个数字,就会分配一个空间,创建11,然后b指向11。

        大家都知道基本类型是可以用==来比较是否相同的(浮点型的先抛开),==这样就是在比较地址,栈的这种共享机制,保证了相同数据的地址一定是相同的。浮点型的比较特殊,他的特殊在于数据的不准确,有些时候你也用==来比较,也没发现有什么错误,但是当你比较(0.999999999999999999999999999999999999999999999f==1f ),你会发现结果是true,但是这里是不是java认为地址相同没有资料考证,浮点型的判断一般都是在差值在一定的误差内,就认为是相等的,java也提供了一些方法用来判断。例如Float.floatToIntBits,全部都进行转化,然后再判断。或者直接用bigdecimal。

 

    

展开阅读全文
加载中
点击引领话题📣 发布并加入讨论🔥
打赏
0 评论
1 收藏
0
分享
返回顶部
顶部