首页 > 其他分享 >C语言输出函数printf详解

C语言输出函数printf详解

时间:2024-07-28 18:53:42浏览次数:18  
标签:输出 include int long C语言 详解 printf 占位

printf

1.1 基本类型

printf()的作用是将参数文本输出到屏幕。
f代表 format(格式化),表示可以定制输出文本的格式。
printf()的头文件是stdio.h

例如:

#include<stdio.h>

int main()
{
	printf("Hello World");

	return 0;
}

1.2 占位符

printf()可以在输出文本中指定占位符,占位符这个位置可以用其他值代入。
占位符的第一个字符一律为百分号%,第二个字符表示占位符的类型。

例如:

#include<stdio.h>

int main()
{
	int a = 90;
	printf("小明的体重是%d公斤\n", a);
	//输出结果是"小明的体重是90公斤"
	return 0;
}

文本中可以使用多个占位符。
printf()参数与占位符是一一对应的关系,如果有n个占位符,printf()的参数有n+1个。

例如:

#include<stdio.h>

int main()
{
	int a = 90;
	int b = 175;
	printf("小明的体重是%d公斤,身高是%d\n", a,b);
	//输出结果是"小明的体重是90公斤,身高是175"
	return 0;
}

如果参数的个数少于对应的占位符,printf()可能会输出内存中的任意值。

例如:

#include<stdio.h>

int main()
{
	int a = 90;
	int b = 175;
	printf("小明的体重是%d公斤,身高是%d\n", a);
	//输出结果是"小明的体重是90公斤,身高是-842139328"
	return 0;
}

1.3 占位符列举

  • %a:十六进制浮点数,字母输出为小写。
  • %A:十六进制浮点数,字母输出为大写。
  • %c:字符。
  • %d:十进制整数。//int
  • %e:使用科学计数法的浮点数,指数部分的e为小写。
  • %E:使用科学计数法的浮点数,指数部分的e为大写。
  • %i:整形,基本等同于%d。
  • %f:小数(包含 float 类型和 double 类型)。//float -> %f double -> %lf
  • %g :6个有效数字的浮点数。整数部分y一旦超过6位,就会自动转为科学计数法,指数部分的e为小写。
  • %G :等同于%g ,唯一的区别是指数部分的 E 为大写。
  • %hd :十进制short int类型。
  • %ho :八进制short int类型。
  • %hx :十六进制short int类型。
  • %hu :unsigned short int类型。
  • %ld :十进制long int类型。
  • %lo :八进制long int类型。
  • %lx :十六进制long int类型。
  • %lu :unsigned long int类型。
  • %lld :十进制long long int类型。
  • %llo :八进制long long int类型。
  • %llx :十六进制long long int类型。
  • %llu :unsigned long long int类型。
  • %Le :科学计数法表示的long double类型浮点数。
  • %Lf :long double类型浮点数。
  • %n :已输出的字符串数量。该占位符本身不输出,只将值存储在指定变量之中。
  • %o :八进制整数。
  • %p :指针(用来打印地址)。
  • %s :字符串。
  • %u :无符号整数(unsigned int)。
  • %x :十六进制整数。
  • %zd :size_t 类型。
  • %% :输出一个百分号。

1.4 限定宽度

printf()允许限定占位符的最小宽度

例如:

#include<stdio.h>                                            

int main()                                              
{
	printf("%5d\n", 123); // 输出为"  123"                                              

	return 0;                                              
}

其中%5d宽度至少为5位,不满5位前面加空格,右对齐。
%-5d右对齐,其他与%5d一样。

例如:

#include<stdio.h>  

int main()  
{
	printf("%-5d\n", 123); // 输出为"123  "  

	return 0;  
}

对于小数,这个限定符会限制所有数字的最小显示宽度

例如:

#include <stdio.h>

int main()
{
	printf("%12f\n", 123.45);// 输出"  123.450000"

	return 0;
}

1.5 限定小数位

输出小数时,有时希望限定小数的位数。举例来说,希望小数点后面只保留两位,占位符可以写成%.2f

例如:

#include <stdio.h>   

int main()   
{
	printf("Number is %.2f\n", 0.5);// 输出"Number is 0.50"

	return 0;   
}

最小宽度和小数位数这两个限定值,都可以用*代替,通过printf()的参数传入。

例如:

#include <stdio.h>   

int main()   
{
	printf("%*.*f\n", 6, 2, 0.5);// 等同于printf("%6.2f\n", 0.5);

	return  0;   
}

1.6 输出部分字符串

%s占位符用来输出字符串,默认是输出全部。如果只要输出开头的部分,可以用%.[m]s指定输出的长度,其中[m]代表一个数字,表示要输出的长度。

例如:

#include <stdio.h>

int main()
{
	printf("%.5s\n", "hello world");//输出"hello"

	return 0;
}

标签:输出,include,int,long,C语言,详解,printf,占位
From: https://blog.csdn.net/wjl060115/article/details/140725587

相关文章

  • 2024牛客多校第四场F.Good Tree 挑战全网最详解
    好吧标题党了一回,但我相信有不少人被出题人的那句“手玩一下就知道了”无语住了像我这种憨憨一旦想偏了就救不回来了,于是困惑了好久,在雨巨的指导下彻底搞懂(此处大声谢谢雨巨,又有实力又会讲题又认真答疑每一个问题,呜呜呜我永远的姐)题意简单来说就是定义f(i)为树上i点到其他所有......
  • 科普文:详解 JuiceFS 读性能:预读、预取、缓存、FUSE 和对象存储
    在高性能计算场景中,往往采用全闪存架构和内核态并行文件系统,以满足性能要求。随着数据规模的增加和分布式系统集群规模的增加,全闪存的高成本和内核客户端的运维复杂性成为主要挑战。JuiceFS,是一款全用户态的云原生分布式文件系统,通过分布式缓存大幅提升I/O吞吐量,并使用成本......
  • STM32F103 SPI详解及示例代码
    1SPI协议详解 SPI是串行外设接口(SerialPeripheralInterface)的缩写,是美国摩托罗拉公司(Motorola)最先推出的一种同步串行传输规范,也是一种单片机外设芯片串行扩展接口,是一种高速、全双工、同步通信总线,所以可以在同一时间发送和接收数据,SPI没有定义速度限制,通常能达到甚至超过10......
  • C语言经典小游戏之三子棋
    目录一、代码思路二、代码实现1.菜单2.实现棋盘3.玩家下棋 4.电脑下棋5.判断输赢三、代码1.game.h代码3.game.c代码3.test.c代码 一、代码思路首先需要创建三个文件:test.c    //用于测试游戏的逻辑性game.c  //游戏代码的实现game.h  //游......
  • Cat 详解
    优质博文:IT-BLOG-CN一、简介Cat[CentralApplicationTracking]是基于Java开发的分布式实时监控系统,有一个非常强大和丰富的可视化报表界面,在Cat提供的报表界面中有非常多的功能,几乎能看到你想要的任何维度的报表数据。缺点就是集成的时候具有代码的侵入性。在中间件(RPC、......
  • Java 多线程技术详解
    文章目录Java多线程技术详解目录引言多线程的概念为什么使用多线程?多线程的特征多线程的挑战多线程的实现方式3.1继承`Thread`类示例代码:3.2实现`Runnable`接口示例代码:3.3使用`Executor`框架示例代码:3.4使用`Callable`和`Future`示例代码:线程的生命......
  • (BS ISO 11898-1:2015)CAN_FD 总线协议详解5- MAC子层描述3
    目录 创作不易,请帮忙点赞+评论+转载,非常感谢5.4.3MACRF(远程帧)规范5.4.3.1描述5.4.3.2MACDF和MACRF相同的字段5.4.3.3仲裁字段5.4.3.4控制字段5.4.4错误帧(EF)的规范5.4.4.1描述5.4.4.2错误标志5.4.4.3错误分隔符5.4.5过载帧(OF)的规定5.......
  • C语言笔记
    各位同好,作为一名C语言学习小白,在经过了一个学期的学习后我拿到了满分的期末成绩,现分享给大家自认为宝贵的笔记。开始写一些C语言的笔记取位数个位:n%10十位:n/10%10百位:n/100%10冒泡排序for(i=1;i<=n-1;i++)     for(j=0;j<n-i;j++)     ......
  • 【C语言】文件操作,文件读写详细介绍
    目录为什么要使用文件?文件概念1.什么是文件?2.程序文件3.数据文件4.文件名文件的使用1.文件指针2.文件的打开与关闭文件的顺序读写 1.顺序读写函数2.scanf系列与printf系列文件的随机读写 1.fseek2.ftell3.rewind文本文件,二进制文件 文件读取结......
  • 音频编码基础详解
    音频编码是将音频信号转换成数字数据的过程,使其能够在计算机系统中存储、处理和传输。音频编码的目的是在保持音质的同时,尽可能地减少数据量。以下是音频编码的详细讲解:音频编码的基本原理采样:将连续的模拟音频信号转换成离散的数字信号。每秒钟对音频信号进行的采样次数称为采......