当前位置: 代码迷 >> 综合 >> C语言 基础十一 输入输出
  详细解决方案

C语言 基础十一 输入输出

热度:90   发布时间:2024-01-30 10:22:14.0

一、scanf() 和 printf() 函数
int scanf(const char *format, …) 函数从标准输入流 stdin 读取输入,并根据提供的 format 来浏览输入。

int printf(const char *format, …) 函数把输出写入到标准输出流 stdout ,并根据提供的格式产生输出。

format 可以是一个简单的常量字符串,但是您可以分别指定 %s、%d、%c、%f 等来输出或读取字符串、整数、字符或浮点数。还有许多其他可用的格式选项,可以根据需要使用。如需了解完整的细节,可以在下文中找到。现在让我们通过下面这个简单的实例来加深理解:

实例
#include <stdio.h>
int main( ) {char str[100];int i;printf( "Enter a value :");scanf("%s %d", str, &i);printf( "\nYou entered: %s %d ", str, i);printf("\n");return 0;
}

当上面的代码被编译和执行时,它会等待您输入一些文本,当您输入一个文本并按下回车键时,程序会继续并读取输入,显示如下:

Enter a value :runoob 123
You entered: runoob 123 

需注意:

  • scanf 要“&”不要“\n” (scanf ("%dlf\n",&a); , 带“\n”时必须随意输入两次)
  • 在读取字符串时,只要遇到一个空格,scanf() 就会停止读取
  • printf 语句中,“\n”之前和之后的空格含义不同,前面无影响,后面空格则会影响下一 行输出语句 ,如(printf ("%d\n ",a); “\n”后面的空格会成为下一行输出信息的第一位“ ”)

1、printf()函数的调用格式为:printf("<格式化字符串>", <参量表>);
printf() 函数的声明:

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

format – 这是字符串,包含了要被写入到标准输出 stdout 的文本。它可以包含嵌入的 format 标签,format 标签可被随后的附加参数中指定的值替换,并按需求进行格式化。format 标签属性是 %[flags][width][.precision][length]specifier。

规定符:

  • %d 十进制有符号整数
  • %u 十进制无符号整数
  • %f 浮点数
  • %s 字符串
  • %c 单个字符
  • %p 指针的值
  • %e 指数形式的浮点数
  • %x, %X 无符号以十六进制表示的整数
  • %o 无符号以八进制表示的整数
  • %g 把输出的值按照 %e 或者 %f 类型中输出长度较小的方式输出
  • %p 输出地址符
  • %lu 32位无符号整数
  • %llu 64位无符号整数
flags(标识) 描述
- 在给定的字段宽度内左对齐,默认是右对齐(参见 width 子说明符)。
+ 强制在结果之前显示加号或减号(+ 或 -),即正数前面会显示 + 号。默认情况下,只有负数前面会显示一个 - 号。
空格 如果没有写入任何符号,则在该值前面插入一个空格。
# - 与 o、x 或 X 说明符一起使用时,非零值前面会分别显示 0、0x 或 0X。
- 与 e、E 和 f 一起使用时,会强制输出包含一个小数点,即使后边没有数字时也会显示小数点。默认情况下,如果后边没有数字时候,不会显示显示小数点。
- 与 g 或 G 一起使用时,结果与使用 e 或 E 时相同,但是尾部的零不会被移除。
0 在指定填充 padding 的数字左边放置零(0),而不是空格(参见 width 子说明符)。
width(宽度) 描述
(number) 要输出的字符的最小数目。如果输出的值短于该数,结果会用空格填充。如果输出的值长于该数,结果不会被截断。
* 宽度在 format 字符串中未指定,但是会作为附加整数值参数放置于要被格式化的参数之前。
.precision(精度) 描述
.number - 对于整数说明符(d、i、o、u、x、X):precision 指定了要写入的数字的最小位数。如果写入的值短于该数,结果会用前导零来填充。如果写入的值长于该数,结果不会被截断。精度为 0 意味着不写入任何字符。
- 对于 e、E 和 f 说明符:要在小数点后输出的小数位数。
- 对于 g 和 G 说明符:要输出的最大有效位数。
- 对于 s: 要输出的最大字符数。默认情况下,所有字符都会被输出,直到遇到末尾的空字符。
- 对于 c 类型:没有任何影响。当未指定任何精度时,默认为 1。如果指定时不带有一个显式值,则假定为 0。
.* 精度在 format 字符串中未指定,但是会作为附加整数值参数放置于要被格式化的参数之前。
length(长度) 描述
h 参数被解释为短整型或无符号短整型(仅适用于整数说明符:i、d、o、u、x 和 X)。
l 参数被解释为长整型或无符号长整型,适用于整数说明符(i、d、o、u、x 和 X)及说明符 c(表示一个宽字符)和s(表示宽字符字符串)。
L 参数被解释为长双精度型(仅适用于浮点数说明符:e、E、f、g 和 G)。

2、scanf() 函数有返回值且类型 int 型,当发生错误时立刻返回 EOF。

scanf() 函数返回的值为:正确按指定格式输入变量的个数;也即能正确接收到值的变量个数。
实例:

#include <stdio.h>
#include <stdlib.h>
int main()
{int a;int b;int c;printf("请输入三个整数:");int x=scanf("%d%d%d",&a,&b,&c);printf("d%\n%d\n",a,x);
}

测试结果:
输入三个格式正确的变量:

请输入三个整数:1 2 3
1
3

其中输入一个格式不正确的变量:

请输入三个整数:5 6 d
5
2

二、getchar() & putchar() 函数
int getchar(void) 函数从屏幕读取下一个可用的字符,并把它返回为一个整数。这个函数在同一个时间内只会读取一个单一的字符。您可以在循环内使用这个方法,以便从屏幕上读取多个字符。

int putchar(int c) 函数把字符输出到屏幕上,并返回相同的字符。这个函数在同一个时间内只会输出一个单一的字符。您可以在循环内使用这个方法,以便在屏幕上输出多个字符。

实例

#include <stdio.h>int main( )
{int c;printf( "Enter a value :");c = getchar( );printf( "\nYou entered: ");putchar( c );printf( "\n");return 0;
}

结果

Enter a value :runoobYou entered: r

getchar()方法只能获取单一字符,如果要获取字符串,可以使用循环:

int c;
while( (c = getchar()) != "\n")  //文件的话!= EOF
{} 

三、gets() & puts() 函数
char *gets(char *s) 函数从 stdin 读取一行到 s 所指向的缓冲区,直到一个终止符或 EOF。

int puts(const char *s) 函数把字符串 s 和一个尾随的换行符写入到 stdout。

实例

#include <stdio.h>int main( )
{char str[100];printf( "Enter a value :");gets( str );printf( "\nYou entered: ");puts( str );return 0;
}

结果

Enter a value :runoobYou entered: runoob

注意:linux系统下需要这样编译:不支持 gets 与 puts, 需要用 fgets 和 fputs。

实例

#include <stdio.h>int main()
{char c[100];printf("Enter a value:");fgets( c,100,stdin );printf("\nyou entered:");fputs( c,stdout );return 0;}

结果

Enter a value:runoobyou entered:runoob
  相关解决方案