A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 马金池 中级黑马   /  2013-1-16 21:50  /  1654 人查看  /  6 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

  1. for(float x=0;x<10.0;x++)
  2.                 {
  3.                        
  4.                         System.out.println(x/10);
  5.                 }
复制代码
这里面的x=0.0的话就会报错,为什么

6 个回复

倒序浏览
0.0是属于double类型的,你赋值给float,会有精度丢失警告。你应该写成0.0f
回复 使用道具 举报
损失精度.....肯定会报错,你换成doule ,再次运行,肯定不会错
for(double x=0.0 ;x<10.0;x++){
     System.out.println(x/10);
   }
回复 使用道具 举报
你这里还是没有搞清楚数据类型, 你在复习一下数据类型吧!你把double类型的数据赋值给float的变量x你说能行吗?就像一个定时炸弹放在你家里你愿意吗?这里同样,不是float类型的数据float会接受吗?
第一种修改方式,把0.0改为float类型
  1. for(float x=0.0f; x < 10.0; x++)
  2. {
  3. System.out.println(x/10 + " " + x);
  4. }
复制代码
第二种方把0.0强制类型装换为float类型,赋值给float类型的变量x
  1. for(float x=(float)0.0; x < 10.0; x++)
  2. {
  3. System.out.println(x/10 + " " + x);
  4. }
复制代码

评分

参与人数 1技术分 +1 收起 理由
冯海霞 + 1

查看全部评分

回复 使用道具 举报
楼上说得很详细,你一个循环搞得这么麻烦干嘛?直接用int就行了啊。
回复 使用道具 举报
注意:整数默认为int,小数默认为double(定义float时,一定要在小数后加f,1.23f)
float x=0.0;    你这样写,java在编译时认0.0是double型的,报可能损失精度的错误。0.0是double型的不能赋给float型。

float x=0;     //编译通过
System.out.println("x="+x);       //运行通过,x=0.0

QQ截图20130116222943.jpg (9.74 KB, 下载次数: 59)

损失精度

损失精度

QQ截图20130116223233.jpg (6.72 KB, 下载次数: 50)

x=0.0

x=0.0

评分

参与人数 1技术分 +1 收起 理由
冯海霞 + 1

查看全部评分

回复 使用道具 举报
1,不同类型数据间的优先关系:

  低----------------------------------------------->高

  byte,short,char —> int —> long —> float —>double

2,强制类型转换:高级数据要转换成低级数据,需要用到强制类型转换。
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马