磁悬浮青蛙呱呱呱 2016-05-12 03:05 采纳率: 0%
浏览 1570

code::blocks中把10^9定义成double型没有溢出定义成long double型却溢出

code::blocks(GNU GCC Complier)中把10^9定义成double型没有溢出,定义成long double型反倒溢出了。而10^9既没有超过double的范围,更没有超过Long double的范围,这是GNU GCC Complier的bug吗?我的code::blocks是16.01的,已经是最新版了。

#include
#include

double a;
long double b;

int main()

{
a=1E9;
b=a;
printf(" sizeof_Double=%d\n 2^63=%e\n a=%e\n",sizeof(double),pow(2,63),a);
printf(" sizeof_LongDouble=%d\n 2^95=%e\n b=%e\n",sizeof(long double),pow(2,95),b);
return 0;

}
图片说明
图片说明

​关于如何输出b,如果使用%e,%f或%lf,有警告:format '%e'(或者'%f','%lf') expects argument of type 'double', but argument 4 has type 'long double' [-Wformat=].如果使用小写的l,有警告:unknown conversion type character 0xa in format [-Wformat=].too many arguments for format [-Wformat-extra-args].如果使用大写的L,有警告:unknown conversion type character 'L' in format [-Wformat=]. too many arguments for format [-Wformat-extra-args]

我的处理器也是64位的,指令集 x86, x86-64, MMX, SSE, SSE2, SSE3, SSSE3, SSE4.1, SSE4.2, AVX, AVX2, FMA, AES
图片说明

  • 写回答

2条回答

  • lm_whales 2016-05-12 04:01
    关注

    printf 使用错误而已
    long double 有两种输出格式
    1)%lf
    这种格式 float,用 %hf,double 用 %f输出,long double 用 %lf 输出
    2)%Lf
    这种格式 float ,double用 %f输出,double 用 %lf(标准中,最初没有,后来补充为可选项),long double 用 %Lf 输出
    增经用 code::blocks 的某个版本,就是这样的,具体选项,没记住
    不同选项输出方式不同
    具体如何组合,记得不很清楚,大约 就是这样吧

    %hf,%f,%lf
    %f,%Lf
    %f,%lf,%Lf
    %f,%lf

    评论

报告相同问题?

悬赏问题

  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
  • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
  • ¥16 mybatis的代理对象无法通过@Autowired装填
  • ¥15 可见光定位matlab仿真
  • ¥15 arduino 四自由度机械臂
  • ¥15 wordpress 产品图片 GIF 没法显示
  • ¥15 求三国群英传pl国战时间的修改方法
  • ¥15 matlab代码代写,需写出详细代码,代价私
  • ¥15 ROS系统搭建请教(跨境电商用途)
  • ¥15 AIC3204的示例代码有吗,想用AIC3204测量血氧,找不到相关的代码。