int float精度和范围

飞天影子 2012-12-31 03:42:18
代码如下:
引用
public class Demo3 {

public static void main(String[] args) {
int a=0x7fffffff;
int b = 0x7ffffff0;
System.out.println(a==b);

float fa=a;
float fb=b;
System.out.println(fa==fb);
}

}

下面的float失确了精度,是不是说明float比int要低呢
...全文
435 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
abc41106 2012-12-31
  • 打赏
  • 举报
回复
这个就要看float 的存储方式了。 float长度32位,其中1位是符号位,8位是幂,剩下的23位是尾数。所以它表示不了0x7fffffff这么大的数,所以会有精度损失。 你换成double来表示这个,就绰绰有余了。 推荐两篇文章: http://blog.csdn.net/abing37/article/details/5332798 http://blog.csdn.net/nx0010/article/details/1829741

62,614

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧