首页 | 资讯动态 | linux基础 | 系统管理 | 网络管理 | 编程开发 | linux数据库 | 服务器技术 | linux相关 | linux认证 | 嵌入式 | 下载中心 | 专题 | linux招聘 | 镜像站
OKLinux中文技术站
·设为首页
·加入收藏
·联系我们
系统管理: 中文环境 系统管理 桌面应用 内核技术 | Linux基础: 基础入门 安装配置 常用命令 经验技巧 软件应用 | Linux数据库: Mysql Postgre Oracle DB2 Sybase other
网络管理: 网络安全 网络应用 Linux服务器 环境配置 黑客安全 | 编程开发: PHP CC++ Python Perl Shell 嵌入式开发 java jsp | PHP技术: PHP基础 PHP技巧 PHP应用 PHP文摘
Linux资讯 Linux招聘 Linux专题 Apache | Linux相关: 硬件相关 Linux解决方案 Linux认证 企业应用 其它Unix | 相关下载: 资料下载 参考手册 开发工具 服务器类 软路由 其它
 技术搜索:
会员中心 注册会员 高级搜索  
  → 当前位置:首页>编程开发>java>Java基础>正文

J2SE综合--高手对Java中的浮点数分析

http://www.oklinux.cn  2008-01-20  来源: 赛迪网 striveforever   会员收藏  游客收藏  【 】 

浮点数分为单精度和双精度,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软件开发中几种认识误区   下一篇:高级:走近JavaEE5与Glassfish应用服务器


收藏于收藏夹】 【评论】 【推荐】 【打印】 【关闭
相关文档
·高级:走近JavaEE5与Glassfish应用服务器
·进阶-当前Java软件开发中几种认识误区
·J2ME综合--关于J2ME中RMS的使用解析
·开发框架:AJAX 开发的两种不同的方法
·Java语言深入:关于多线程程序模型研究
·J2SE综合介绍:Java本地接口工作方式初探
·基于JDBC的数据库连接池技术研究与应用
·进阶-看 java 实现的XML schema 验证
·究竟什么叫面向接口编程
·Java高级:Synchronize与JAVA内存模型
·J2SE综合--java通过JNI与delphi交互
·J2SE综合--区分eclipse中的两种JRE
·高级:使用异步Servlet扩展AJAX应用程序
·Java入门--Java入门需掌握的基本概念
·J2SE综合--浅析类型转化与final修饰符
·浅析Spring2.0中新的Bean类型实现原理
发表评论
密码: 匿名评论
评论内容:

(不超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规)
 
  最新文档
·Java入门:状态对象--数据库的替代者
·Java语言怎样调用外部应用程序
·Java语言深入--关于Java语言的内存泄漏
·JSP/Servlet/JSF:Servlet/JSP配置详解
·进阶-怎样使用AJAX进行WEB应用程序开发
·基础:J2ME程序开发之新手入门九大要点
·Java入门--Java语言接口与继承的本质
·JAVA进阶--如何提升JSP应用程序的效率
·对Java中四种XML解析技术之不完全测试
·编写高级 JScript应用代码
·JSP/Servlet/JSF--对标签库的深入研究
·Java入门--关于字符串分割的两种方法
  阅读排行
·使用AJAX技术实现网页无闪自动局部刷新
·快速教您Apache Tomcat SSL的配置
·Java语言深入--java调用C/C 的过程
·用JSP JavaScript打造二级级联下拉菜单
·JAVA进阶--线程运行栈信息的获取讲解
·J2SE综合--JAVA实现把汉字转化成拼音
·使用WEBWORK实现文件上传方法实例详解
·一个非常有趣的使用spring框架AOP例子
·关于java中相对路径,绝对路径问题总结
·高级:lucene全文检索应用示例及代码简
·详细讲解Struts构架中action的跳转大全
·在Weblogic上配置JMS服务的方法
·Hibernate配置文件中的映射元素详解
·对Java中四种XML解析技术之不完全测试
·基于AJAX的动态树型结构的设计与实现
网摘收藏: