1、%f 是输出 float 型变量;%f 是输出 double 型变量;%Lf 是输出 long double 型变量。
2、在C语言中,对于数值类型只有通过printf类函数输出这一种方式,比如printf, sprintf, fprintf等。这类函数输出时要求有格式符号,其中long double的格式符号为%Lf。
以下是一个简单的参考代码,输出到标准输出设备。
#include <stdio.h>
int main()
{
long double v = 1.23;
printf("%Lf\n", v);//采用%llf格式输出long double 类型
return 0;
}
拓展资料:
C语言是一门通用计算机编程语言,应用广泛。C语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言。
尽管C语言提供了许多低级处理的功能,但仍然保持着良好跨平台的特性,以一个标准规格写出的C语言程序可在许多电脑平台上进行编译,甚至包含一些嵌入式处理器(单片机或称MCU)以及超级电脑等作业平台。
二十世纪八十年代,为了避免各开发厂商用的C语言语法产生差异,由美国国家标准局为C语言制定了一套完整的美国国家标准语法,称为ANSI C,作为C语言最初的标准。目前2011年12月8日,国际标准化组织(ISO)和国际电工委员会(IEC)发布的C11标准是C语言的第三个官方标准,也是C语言的最新标准,该标准更好的支持了汉字函数名和汉字标识符,一定程度上实现了汉字编程。
如果是【输出printf】的输出项是double或float时,可以用f或e作为格式描述字符,(其中double也可以用%lf或%le)。
注意:如果是【输入scanf】的输入项为double时,则必须用%lf或%le【必须有个l】作为格式描述字符。位于输入项为float与上面的一致。
这个很重要哦!特别是scanf,别搞错了,二级选择题都会考哦!
以下是一个简单的参考代码,输出到标准输出设备。
#include <stdio.h>int main(){ long double v = 1.23; printf("%llf\n", v);//采用%llf格式输出long double 类型 return 0;}
关于long double, 需要说明的是,在原始的C标准中是没有这个类型的,C99中才添加了该类型。而在C99及后续的规范中,对于该类型规定的也并不详细,只是要求long double类型在精度上需要不少于double的精度。于是就出现了有的编译器不支持long double, 而支持的编译器在实现上也有所区别,目前常见的long double有占用8字节,10字节,12字节和16字节四种,但输出格式都是相同的%llf。 如果想知道使用的编译器是如何实现的,可以用printf("%d", sizeof(long double));输出long double占用的空间值。
long ;long
double
占用多少内存空间可能会有所不同。
你可以用下面的程序得到:
#include
#include
#include
int
main(void)
{
printf("long
long
int
的范围从%lld到%lld,
占用空间为%d个字节\n",llong_min,llong_max,sizeof(long
long));
printf("long
double
的范围从%le到%le,
占用空间为%d个字节\n",ldbl_min,ldbl_max,sizeof(long
double));
}
就我的编译器来说,其结果为:
也就说说long
long占8个字节,long
double占16个字节。
而且从程序中也可看到,long
long的控制字符是%lld,long
double的是%le