1、输入输出函数
C语言中stdio.h
头文件中内置输入输出函数,如下列出:
printf
与scanf
getchar
与putchar
gets
与puts
输入输出函数中 scanf
与printf
功能比较丰富,但操作稍微复杂。
2、scanf() 和 printf() 函数
scanf()
和 printf()
是C语言中最常用的输入和输出函数。scanf()
用于格式化输入,而 printf()
用于格式化输出。
int scanf(const char *format, ...)
函数从标准输入流 stdin 读取输入,并根据提供的 format 来浏览输入。
int printf(const char *format, ...)
函数把输出写入到标准输出流 stdout ,并根据提供的格式产生输出。
format
可以是一个简单的常量字符串,但是可以分别指定 %s
、%d
、%c
、%f
等来输出或读取字符串、整数、字符或浮点数。还有许多其他可用的格式选项,可以根据需要使用。
1)printf()常用格式输出
格式: %[-][0][m][l]格式字符
附加格式说明字符 | 说 明 |
- | 输出的数字或字符以左对齐, 右边填空格 |
0(数字) | 输出的空位用0填充。 |
m(一个正整数) | 输出数据的字段宽度。 如果实际位数多于m, 按实际位数输出; 如果实际位数少于m, 则补以空格或0。 |
.n(一个正整数) | 对实数,表示输出n位小数; 对字符串, 表示截取的字符个数。 |
l(字母) | 输出长整型整数 |
%d :以带符号的十进制形式输出整数
%o :以无符号的八进制形式输出整数
%x :以无符号的十六进制形式输出整数
%u :以无符号的十进制形式输出整数
%c :以字符形式输出单个字符
%s :输出字符串
%f :以小数点形式输出单、双精度实数
%e :以标准指数形式输出单、双精度实数
%g :选用输出宽度较小的格式输出实数
例如,
#include <stdio.h>
int main( )
{
char x='a';
int i=98;
printf("%c,%d\n",x,x);
printf("%c,%d\n",i,i);
printf("%3s,%-6s,%-5.2s,%4.3s,%.3s,","hello",
"hello","hello","hello","hello");
float f=3.14159;
printf("%f,%07.3f,%-7.3f,%10f,%.3f,",f,f,f,f,f);
printf("\n,%10.1e",31.5);
int i1=-1;
printf("\n%d,%o,%x,%u",i1,i1,i1,i1);
float f1=3.14159;
printf("\n%e,%f,%lf,%g",f1,f1,f1,f1);
return 0;
}
2)scanf()格式输入
格式符 | 说明 |
d | 用于输入十进制整数 |
o | 用于输入八进制形整数 |
x | 用于输入十六进制整数 |
c | 用于输入一个字符 |
s | 用于输入字符串, 并将字符串送到一个字符数组中。 输入时以非空白字符开始, 第一个空白字符结束。 字符串以串结束标志“\0”作为其最后一个字符。 |
f | 用于输入实数。 输入时用小数点形式或指数形式均可。 (输入双精度必须用%lf,否则不能正常输入) |
e | 与f作用相同 |
附加格式
* | 表示本输入项在输入后不赋给相应的变量。(不存储) |
l(字母) | 用于输入长整型和双精度实型数据 |
m(一个正整数) | 用于输入长整型和双精度实型数据 |
scanf()格式字符串的组成:
格式符:和printf
函数类似,scanf
函数的格式字符串以%开始,以一个格式字符结束,中间可以插入附加字符。格式符告诉了scanf函数该读取什么样的数据。
空白符:空白符可以是空格(space,用空格键输入)、制表符(tab,用Tab键输入)和新行符(newline,用回车键输入),或者它们的组合
非空白符:除去格式说明符合空白符之外,就是非空白符。非空白符在用户输入的时候,也必须一并输入。非空白符使scanf()
在缓冲区中读一个匹配的字符并将这个字符忽略。例如,”%d,%d”
使scanf()
先读入一个整数,接着必须要读入一个逗号,读入到逗号后,表示格式匹配,将读入的逗号丢弃,而不像读入的整数存储到某个内存空间。读入逗号后,接着读入另一个整数。如发现不能匹配格式字符串,比如没有读到逗号,scanf()
返回,读入失败。
例如,
#include <stdio.h>
int main( )
{
int i,j;
scanf("%3d%3d\n",&i,&j); // 输入:1234567↙
printf("%d,%d\n",i,j); // 输出 123,456
// %后面的*格式符,用来表示在解析时,将读入的数据忽略不赋给任何变量。如:
int i1,j1;
scanf("%d %*d %d\n",&i1,&j1); // 输入: 123 456 789
printf("%d,%d\n",i1,j1); // 输出: 123,789
// 输入数据时不能指定精度。如:
float f;
scanf("%7.2f\n",&f); // 输入 123.456
printf("%f23\n",f); // 输出 0.00000023
// 输入双精度数使用%lf
// 输入双精度浮点数时,务必用%lf,如下错误
double db;
scanf("%f\n",&db); //输入: 123.456
printf("%f\n",db); // 输出 : 0.000000
return 0;
}
3)scanf() 和 fgets() 的区别及注意
scanf("%s", str)
只能读取一个单词,遇到空格就停止,而 fgets()
可以读取整行字符串,包括空格。使用 scanf() 时需要注意缓冲区问题,scanf()
在读取字符时,可能会因为前面的换行符而导致读取问题。可以在读取字符前添加一个空格来跳过前面的空白字符。
3、字符输入输出(getchar/putchar)
getchar()
和 putchar()
是最基础的字符输入和输出函数,用于从标准输入读取单个字符和将单个字符写入标准输出。有时在显示器屏幕上打印或从控制台获取一个字符,此时使用功能强大的printf
与scanf
函数,则显得有点于麻烦,C提供了一个库函数putchar
/getchar
来实现。
int getchar(void)
函数从屏幕读取下一个可用的字符,并把它返回为一个整数。这个函数在同一个时间内只会读取一个单一的字符。可以在循环内使用这个方法,以便从屏幕上读取多个字符。
int putchar(int c)
函数把字符输出到屏幕上,并返回相同的字符。这个函数在同一个时间内只会输出一个单一的字符。可以在循环内使用这个方法,以便在屏幕上输出多个字符。
例如,
#include <stdio.h>
int main( )
{
int c;
printf( "请输入一个字符 :");
c = getchar( );
printf( "\n输入的字符是: ");
putchar( c );
printf( "\n");
return 0;
}
注意:执行时会等待输入一些文本,当输入多个字符并按下回车键时,程序会继续并只会读取一个字符。
4、gets() 和 puts() 函数
gets()
和 puts()
用于读取和输出字符串,puts
函数功能非常单一,在显示器屏幕上输出一个字符串,并换行。gets
从标准输入设备读字符串函数。可以无限读取,不会判断上限,以回车结束读取,所以程序员应该确保buffer
的空间足够大,以便在执行读操作时不发生溢出。此函数在stdio.h
头文件中定义的。gets()
不会检查输入的长度,如果输入超过数组大小,可能导致缓冲区溢出,进而引发安全漏洞。因为这个原因,gets()
在C11标准中已被移除。
char *gets(char *s)
函数从 stdin 读取一行到 s 所指向的缓冲区,直到一个终止符或 EOF。
int puts(const char *s)
函数把字符串 s 和一个尾随的换行符写入到 stdout。
例如,
#include <stdio.h>
int main( )
{
char str[100];
printf( "请输入字符串 :");
gets( str );
printf( "\n输入的内容: ");
puts( str );
return 0;
}
注意:执行时会等待输入一些文本,当输入多个字符并按下回车键时,程序会继续并读取一整行直到该行结束。在读取字符串时,可以使用 fgets()
代替 gets()
以避免缓冲区溢出。