scanf和printf介绍

1.scanf

scanf函数是C语言中标准库中的输入函数,其主要作用是从标准输入设备(如键盘)获取输入数据,并将读取的数据存储到指定的变量中。其基本用法如下:

  1. 读取整型数据:
int num;
scanf("%d", &num); // 从标准输入读取一个整数,并将其存储到变量num中
  1. 读取浮点型数据:
float f;
scanf("%f", &f); // 从标准输入读取一个浮点数,并将其存储到变量f中
  1. 读取字符:
char ch;
scanf("%c", &ch); // 从标准输入读取一个字符,并将其存储到变量ch中
  1. 读取字符串:
char str[100];
scanf("%s", str); // 从标准输入读取一个字符串,并将其存储到字符数组str中
  1. 读取多个数据:
int a, b, c;
scanf("%d %d %d", &a, &b, &c); // 从标准输入读取三个整数,并将其存储到变量a、b、c中
  1. 使用scanf的返回值:

scanf函数的返回值为读入的变量数量,即成功读取并存储的变量个数。因此,可以利用scanf函数返回值来判断输入是否合法:

int a, b;
if (scanf("%d %d", &a, &b) != 2) {
    // 输入格式错误,需要重新输入
}

printf() 是在标准库的头⽂件 stdio.h 定义的。使⽤这个函数之前,必须在源码⽂件头部引⼊这
个头⽂件

1.1占位符

在C语言中,占位符是指在格式化输出函数(如printf)和格式化输入函数(如scanf)中用来表示输出或输入不同类型的数据的特殊字符。下面是一些常用的占位符及其用法:

  1. %c:输出/输入一个字符
char c = 'A';
printf("%c\n", c); // 输出字符'A'

char c;
scanf("%c", &c); // 从标准输入读取一个字符,并将其存储到变量c中
  1. %d或%i:输出/输入一个带符号的十进制整数
int num = 123;
printf("%d\n", num); // 输出整数123

int num;
scanf("%d", &num); // 从标准输入读取一个整数,并将其存储到变量num中
  1. %u:输出/输入一个无符号的十进制整数
unsigned int num = 123;
printf("%u\n", num); // 输出无符号整数123

unsigned int num;
scanf("%u", &num); // 从标准输入读取一个无符号整数,并将其存储到变量num中
  1. %f:输出/输入一个浮点数
float f = 1.23;
printf("%f\n", f); // 输出浮点数1.23

float f;
scanf("%f", &f); // 从标准输入读取一个浮点数,并将其存储到变量f中
  1. %s:输出/输入一个字符串
char str[] = "Hello";
printf("%s\n", str); // 输出字符串"Hello"

char str[100];
scanf("%s", str); // 从标准输入读取一个字符串,并将其存储到字符数组str中
  1. %p:输出一个指针的地址
int num = 123;
printf("%p\n", &num); // 输出变量num的地址

int *p;
scanf("%p", &p); // 从标准输入读取一个指针,并将其存储到指针变量p中

除上述占位符外,还有其他占位符用于输出/输入不同类型的数据,如%x或%X用于输出/输入一个带符号/无符号的十六进制整数,%o用于输出/输入一个八进制整数,%e或%E用于输出/输入一个带指数的浮点数等。需要根据具体情况选用合适的占位符。

2.printf

在C语言中,printf是一个标准库函数,用于格式化输出数据。它可以将文本和变量按照指定的格式输出到控制台或文件中。

printf函数的原型如下:

int printf(const char *format, ...);

其中,第一个参数format是输出格式字符串,包含普通字符和格式化占位符。第二个及后面的参数是要输出的变量。

下面是一个例子:

int num = 123;
char ch = 'A';
float f = 1.23;

printf("num=%d, ch=%c, f=%f\n", num, ch, f);

上述代码将输出:

num=123, ch=A, f=1.230000

在输出格式字符串中,普通字符会按照原样输出,而占位符则会被相应的变量替换。

常用的格式化占位符包括:

  • %d或%i:输出一个带符号的十进制整数
  • %u:输出一个无符号的十进制整数
  • %f:输出一个浮点数
  • %c:输出一个字符
  • %sv:输出一个字符串
  • %p:输出一个指针的地址

除此之外,还有其他的格式化占位符可供使用,如%x或%X用于输出/输入一个带符号/无符号的十六进制整数,%o用于输出/输入一个八进制整数,%e或%E用于输出/输入一个带指数的浮点数等。
需要注意的是,在输出格式字符串中,所有的占位符都必须与对应的变量类型匹配,否则会导致输出结果出错。
除了基本的格式化输出之外,printf函数还支持一些高级用法,如控制输出宽度、精度、对齐方式等。需要根据具体情况选择合适的输出格式,以达到所需的输出效果。

  • 6
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值