2 pijianzhirui pijianzhirui 于 2016.05.12 11:05 提问

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
lm_whales   Rxr 2016.05.12 12: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

netgator
netgator   2016.05.15 14:39

If you want to use "%Lf" in printf, add "#define USE_MINGW_ANSI_STDIO 1" before your "#include "

netgator
netgator before your "#include <stdio.h>"
一年多之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!