登录社区:用户名: 密码: 忘记密码 网页功能:加入收藏 设为首页 网站搜索  

文档

下载

图书

论坛

安全

源码

硬件

游戏
首页 信息 空间 VB VC Delphi Java Flash 补丁 控件 安全 黑客 电子书 笔记本 手机 MP3 杀毒 QQ群 产品库 分类信息 编程网站
  立华软件园 - 安全技术中心 - 技术文档 - JAVA 技术文章 | 相关下载 | 电子图书 | 攻防录像 | 安全网站 | 在线论坛 | QQ群组 | 搜索   
 安全技术技术文档
  · 安全配制
  · 工具介绍
  · 黑客教学
  · 防火墙
  · 漏洞分析
  · 破解专题
  · 黑客编程
  · 入侵检测
 安全技术工具下载
  · 扫描工具
  · 攻击程序
  · 后门木马
  · 拒绝服务
  · 口令破解
  · 代理程序
  · 防火墙
  · 加密解密
  · 入侵检测
  · 攻防演示
 安全技术论坛
  · 安全配制
  · 工具介绍
  · 防火墙
  · 黑客入侵
  · 漏洞检测
  · 破解方法
 其他安全技术资源
  · 攻防演示动画
  · 电子图书
  · QQ群组讨论区
  · 其他网站资源
最新招聘信息

Java中的浮点数分析
发表日期:2004-10-30作者:treeroot[转贴] 出处:CSDN  

  浮点数分为单精度和双精度,Java中的单精度和双精度分别为float和double.你们知道float和double是怎么存储的吗?

  float占4个字节,double占8个字节,为了方便起见,这里就只讨论float类型.
  float其实和一个int型的大小是一样的,一共32位,第一位表示符号,2-9表示指数,后面23位表示小数部分.这里不多说,请参考:http://blog.csdn.net/treeroot/archive/2004/09/05/95071.aspx

  这里只举一个例子,希望能抛砖引玉,就是研究一下浮点数0.1的存储形式,先运行这个程序.

 


   public class Test{
  public static void main(String[] args) {
  int x = 0x3d800000;
  int i = 1 << 22;
  int j = 1 << 4;
  float f = 0.1f;
  int y = Float.floatToIntBits(f);
  float rest = f - ( (float) 1) / j;
  while (i > 0) {
  j <<= 1;
  float deta = ( (float) 1) / j;
  if (rest >= deta) {
  rest -= deta;
  x |= i;
  }
  i >>= 1;
  }
  pr(x);
  pr(y);
  }

  static void pr(int i) {
  System.out.println(Integer.toBinaryString(i));
  }

  }
 
  结果:
  111101110011001100110011001101
  111101110011001100110011001101

  程序说明:
  int x=0x3d80000;
  因为浮点表示形式为1.f*2n-127我们要表示0.1,可以知道n-127=-4,到n=123
  符号为正,可知前9是 001111011,暂时不考虑后面的23位小数,所以我们先假设x=0x3d800000;


   int i = 1 << 22;
  i初始为第右起第23位为1,就是x的第10位


   int j = 1 << 4;

  i初始为4,因为n-127为-4,这里是为了求它的倒数.


   float f = 0.1f;
  int y = Float.floatToIntBits(f);

  y就是它的32位表示


   float rest = f - ( (float) 1) / j;

  这个rest表示除了1.f中的1剩下的,也就是0.f


   while (i > 0) {
  j <<= 1;
  float deta = ( (float) 1) / j;
  if (rest >= deta) {
  rest -= deta;
  x |= i;
  }
  i >>= 1;
  }

  这个循环来计算23位小数部分,如果rest不小于deta,表示这个位可以置为1.

  其他的不多说了,输入结果是一样的,可以说0.1这个浮点数肯定是不精确的,但是0.5可以精确的表示,想想为什么吧.

 

 

 

我来说两句】 【发送给朋友】 【加入收藏】 【返加顶部】 【打印本页】 【关闭窗口
中搜索 Java中的浮点数分析

 ■ [欢迎对本文发表评论]
用  户:  匿名发出:
您要为您所发的言论的后果负责,故请各位遵纪守法并注意语言文明。

最新招聘信息

关于我们 / 合作推广 / 给我留言 / 版权举报 / 意见建议 / 广告投放 / 友情链接  
Copyright ©2001-2006 Lihuasoft.net webmaster(at)lihuasoft.net
网站编程QQ群   京ICP备05001064号 页面生成时间:0.00185