C语言中long double的问题
问大家一下,#include<stdio.h>main(){longdoublex;x=2222222222.222226666L;printf("x=%f\n",x);...
问大家一下,
#include<stdio.h>
main()
{
long double x;
x=2222222222.222226666L;
printf("x=%f\n",x);
}
x=2222222222.222227
Press any key to continue
问:Long double 是18~19位。书中说“在编写实型常量时,L表示该常量为long double长双精度类型”。
为什么结果不会是x=2222222222.222226666 呢? 展开
#include<stdio.h>
main()
{
long double x;
x=2222222222.222226666L;
printf("x=%f\n",x);
}
x=2222222222.222227
Press any key to continue
问:Long double 是18~19位。书中说“在编写实型常量时,L表示该常量为long double长双精度类型”。
为什么结果不会是x=2222222222.222226666 呢? 展开
3个回答
展开全部
具体的要参考你所使用的编译器,不过书里写的不见得都对。
一般来讲,long double不应当使用%f,这个错误是最严重的错误之一。(堆栈错误)
此类错误可能导致系统的崩溃,程序不能正常运行等。
有些C编译器没有实现long double,即long double就是double,具体的只能看你的情况了。
如果需要做数值计算,最好使用MPFR之类的,这种浮点数计算只能在精度要求很低的情况下使用,或者具有非常深厚的数学功底。
一般来讲,long double不应当使用%f,这个错误是最严重的错误之一。(堆栈错误)
此类错误可能导致系统的崩溃,程序不能正常运行等。
有些C编译器没有实现long double,即long double就是double,具体的只能看你的情况了。
如果需要做数值计算,最好使用MPFR之类的,这种浮点数计算只能在精度要求很低的情况下使用,或者具有非常深厚的数学功底。
追问
“一般来讲,long double不应当使用%f,这个错误是最严重的错误之一。(堆栈错误)
”那要用什么呢?怎么用呢?
展开全部
1. long double输出时候要用lf修饰 printf("x=%lf\n",x);
2. float ,double ,long double默认输出都是小数点后6位,
double 和long double 想要输出多的话,可以用格式符来输出
printf("x=%.10lf\n",x); 这样就能输出小数点后10位。
2. float ,double ,long double默认输出都是小数点后6位,
double 和long double 想要输出多的话,可以用格式符来输出
printf("x=%.10lf\n",x); 这样就能输出小数点后10位。
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
四舍五入了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询