java不同类型数值的加法问题
publicstaticvoidmain(String[]args){byteb=127;charc='a';shorts=23561;inti=3333;longl=4...
public static void main(String[] args) {
byte b = 127;
char c = 'a';
short s = 23561;
int i = 3333;
long l = 400000L;
float f = 3.14159F;
double d = 54.523;
// 低类型向高类型自动转换
System.out.println("累加bype等于:" + b);
System.out.println("累加char等于:" + (b + c));
System.out.println("累加short等于:" + (b + c + s));
System.out.println("累加int等于:" + (b + c + s + i));
System.out.println("累加long"+l+"等于:" + (b + c + s + i + l));
System.out.println("累加float"+f+"等于:" + (b + c + s + i + l + f));
System.out.println("累加double"+d+"等于:" + (b + c + s + i + l + f + d));
}
输出结果为
累加bype等于:127
累加char等于:224
累加short等于:23785
累加int等于:27118
累加long400000等于:427118
累加float3.14159等于:427121.16
累加double54.523等于:427175.67925
请教最后两行结果是什么原因? 展开
byte b = 127;
char c = 'a';
short s = 23561;
int i = 3333;
long l = 400000L;
float f = 3.14159F;
double d = 54.523;
// 低类型向高类型自动转换
System.out.println("累加bype等于:" + b);
System.out.println("累加char等于:" + (b + c));
System.out.println("累加short等于:" + (b + c + s));
System.out.println("累加int等于:" + (b + c + s + i));
System.out.println("累加long"+l+"等于:" + (b + c + s + i + l));
System.out.println("累加float"+f+"等于:" + (b + c + s + i + l + f));
System.out.println("累加double"+d+"等于:" + (b + c + s + i + l + f + d));
}
输出结果为
累加bype等于:127
累加char等于:224
累加short等于:23785
累加int等于:27118
累加long400000等于:427118
累加float3.14159等于:427121.16
累加double54.523等于:427175.67925
请教最后两行结果是什么原因? 展开
若以下回答无法解决问题,邀请你更新回答
展开全部
这个没有什么好奇怪的 java中浮点型运算经常会出现精度丢失的问题,
不管是float还是dauble都会出现这个问题
不管是float还是dauble都会出现这个问题
追问
愿闻其详
追答
这个没有什么详细的 就是在计算过程中 浮点型的数据会出现精度丢失。
比如你用1.1-0.1f会得到0.99999而不是1.这个是java本身就一直存在的问题
一般精确计算的时候不使用浮点型直接计算,而是使用BigDecimal
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
因为float和double精度不一样
追问
愿闻其详
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询