java 这段代码为什么会算出NaN
classMath{publicstaticfloatdiv(floatx,floaty){floattemp=0;temp=x/y;}}publicclasssecti...
class Math
{ public static float div(float x,float y) {
float temp = 0;
temp = x/y;
}}
public class section7050{
public static void main(String[] args){
float temp = 0;
float i = 0;
float j = 0;
temp = Math.div(i,j);
String st1 = args[0];
String st2 = args[1];
i = Float.parseFloat(st1);
j = Float.parseFloat(st2);
System.out.println(i + " 除 " + j + " = " + temp);
}}
【结果】
D:\persevere>java section7050 10 2
10.0 除 2.0 = NaN
把temp = Math.div(i,j);放在i、j 赋值之后就没有问题
莫非是因为主方法里一定要严格的安排先后顺序? 展开
{ public static float div(float x,float y) {
float temp = 0;
temp = x/y;
}}
public class section7050{
public static void main(String[] args){
float temp = 0;
float i = 0;
float j = 0;
temp = Math.div(i,j);
String st1 = args[0];
String st2 = args[1];
i = Float.parseFloat(st1);
j = Float.parseFloat(st2);
System.out.println(i + " 除 " + j + " = " + temp);
}}
【结果】
D:\persevere>java section7050 10 2
10.0 除 2.0 = NaN
把temp = Math.div(i,j);放在i、j 赋值之后就没有问题
莫非是因为主方法里一定要严格的安排先后顺序? 展开
3个回答
展开全部
float i = 0;
float j = 0;
temp = Math.div(i,j); //temp=0/0,当然就是Float.NaN,意思就是非正常浮点值
放到i = Float.parseFloat(st1);
j = Float.parseFloat(st2);
后,也可能出现NaN,这要看你参数是啥,如果都是0,一样出现NaN
float j = 0;
temp = Math.div(i,j); //temp=0/0,当然就是Float.NaN,意思就是非正常浮点值
放到i = Float.parseFloat(st1);
j = Float.parseFloat(st2);
后,也可能出现NaN,这要看你参数是啥,如果都是0,一样出现NaN
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
temp = Math.div(i,j);
放到
i = Float.parseFloat(st1);
j = Float.parseFloat(st2);
temp = Math.div(i,j);
放到
i = Float.parseFloat(st1);
j = Float.parseFloat(st2);
temp = Math.div(i,j);
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询