c语言,请问用下面的代码用double写就是3.141593,用long double写就是0.0

c语言,请问用下面的代码用double写就是3.141593,用long double写就是0.000000,这是为什么???求解

在0.c下编译,就是输出0.000000

在0.cpp下编译,就能正常输出,要注意使用%Lf格式符:

温馨提示:答案为网友推荐,仅供参考
第1个回答  2019-01-10
语言是一门通用计算机编程语言,应用广泛。C语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言。 尽管C语言提供了许多低级处理的功能,但仍然保持着良好跨平台的特性,以一个标准规格写出的C语言程序可在许多电脑平台上进行编译,甚至包含一些嵌入式处理器(单片机或称MCU)以及超级电脑等作业平台。 二十世纪八十年代,为了避免各开发厂商用的C语言语法产生差异,由美国国家标准局为C语言制定了一套完整的美国国家标准语法,称为ANSI C,作为C语言最初的标准。目前2011年12月8日,国际标准化组织(ISO)和国际电工委员会(IEC)发布的C11标准是C语言的第三个官方标准,也是C语言的最新标准,该标准更好的支持了汉字函数名和汉字标识符,一定程度上实现了汉字编程。

中文名
C语言
外文名
The C Programming Language
类别
计算机通用程序设计语言
创始人
Dennis MacAlistair Ritchie
创始时间
1972年
发源
BCPL语言
主要编译器
Clang、GCC、MSVC、Turbo C等
启发语言
B语言、汇编、ALGOL68
操作系统
多平台
第2个回答  2019-01-09
程序代码本身没有任何问题,我这边用RAD Studio测试运行结果一切正常,我估计和编译器有关,比如你的编译器printf函数不支持%Lf这种表达方式,可能是%LF或其它什么,当然也可能是其它的原因,建议单步调试一下,确定出错的位置。
第3个回答  2019-01-09
long double是什么玩意儿?追问

精确度不少于double的浮点数数据类型……
好像是这么定义的

相似回答