C语言中%d,等等% 的用法,和意义

本文介绍了C语言中的各种数据类型及其在scanf和printf函数中的占位符,包括%d、%f、%a等,并详细解释了格式说明符的使用规则,如对齐方式、宽度和精度控制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#学习记录#

%d是占位符,
%是引导符,d表示十进制整数的形式

例如我用键盘输入一个整数给变量a

写成:scanf("%d",&a);%d 占得就是a的位

再如我在显示器上输出变量a的值

写成:printf("%d",a);%d就是输出的时候的占位符,占a的位 表示以十进制整数形式输出a

%d是用来指定输入和输出时的数据类型和格式,表示“以十进制整数的形式输出”。

%a 浮点数、十六进制数字和p-记数法(C99)


%A    浮点数、十六进制数字和p-记法(C99)


%c     一个字符(char)

%C 一个ISO宽字符

%d    有符号十进制整数(int)(%ld、%Ld:长整型数据(long),%hd:输出短整形。) 

%e    浮点数、e-记数法


%E    浮点数、E-记数法


%f     单精度浮点数(默认float)、十进制记数法(%.nf 这里n表示精确到小数位后n位.十进制计数)

%g    根据数值不同自动选择%f或%e.


%G    根据数值不同自动选择%f或%e.


%i 有符号十进制数(与%d相同)


%o    无符号八进制整数


%p    指针、数组等存储地址的


%s     对应字符串char*(%s == %hs == %hS 输出 窄字符)

%S 对应宽字符串WCAHR*(%ws == %S 输出宽字符串)

%u    无符号十进制整数(unsigned int)


%x    使用十六进制数字0f的无符号十六进制整数 


%X    使用十六进制数字0f的无符号十六进制整数

%#x         带有0x的十六进制整数
%%    打印一个百分号

%I64d用于INT64 或者 long long

%I64u用于UINT64 或者 unsigned long long

%I64x用于64位16进制数据

①%:表示格式说明的起始符号,不可缺少。


②-:有-表示左对齐输出,如省略表示右对齐输出。


③0:有0表示指定空位填0,如省略表示指定空位不填。


④m.n:m指域宽,即对应的输出项在输出设备上所占的字符数。n指精度。用于说明输出的实型数的小数位数。为指定n时,隐含的精度为n=6位。


⑤l或h:l对整型指long型,对实型指double型。h用于将整型的格式字符修正为short型。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值