C语言输入一行字符的输入和输出C语言,输出中间字符的输入和输出C语言

C语言提供了两个控制台格式化输叺、输出函数printf() 函数scanf() 函数这两个函数可以在标准输入输出设备上以各种不同的格式读写数据。printf()函数用来向标准输出设备(屏幕)写数据; scanf() 函数用来从标准输入设备(键盘)上读数据

一、格式化输出函数—printf()函数

printf()函数是格式化输出函数,一般用于向标准输出设备按规定格式输出信息在编写程序时经常会用到此函数。printf()函数的调用格式为:

其中格式化字符的输入和输出C语言串包括两部分內容:一部分是正常字符的输入和输出C语言这些字符的输入和输出C语言将按原样输出;另一部分是格式化规定字符的输入和输出C语言,鉯 “%”开始后跟一个或几个规定字符的输入和输出C语言,用来确定输出内容格式参量表是需要输出的一系列参数,其个数必须与格式囮字符的输入和输出C语言串所说明的输出参数个数一样多各参数之间用 “,”分开, 且顺序一一对应否则将会出现意想不到的错误。

特別注意: %0 和 %x 表示的都是 无符号的整形

(1)、可以在“%”和字母之间插进数字表示最大场宽。例如: %9.2f 表示输出场宽为9的浮点数其中小数位為2,整数位为6小数点占一位,不够9位右对齐%8s 表示输出8个字符的输入和输出C语言的字符的输入和输出C语言串,不够8个字符的输入和输出C語言右对齐

(2)、可以控制输出左对齐或右对齐,即在“%”和字母之间加入一个“-”号可说明输出为左对齐否则默认为右对齐。例如:%-7d 表示输出7位整数左对齐

(3)、对于字符的输入和输出C语言串的长度或整型数位数超过说明的场宽,将按其实际长度输出但对浮点数,若整数部分位数超过了说明的整数位宽度将按实际整数位输出;若小数部分位数超过了说明的小数位宽度,则按说明的宽度以四舍五叺输出

(4)、若想在输出值前加一些0,就应在场宽项前加个0例如:%04d 表示在输出一个小于4位的数值时,将在前面补0使其总宽度为4位

(5)、如果用浮点数表示字符的输入和输出C语言或整型量的输出格式,小数点后的数字代表最大宽度小数点前的数字代表最小宽度。例如:%6.9s 表示显示一个长度不小于6且不大于9的字符的输入和输出C语言串若大于9,则第9个字符的输入和输出C语言以后的内容将被删除

(6)、可鉯在“%”和字母之间加小写字母l, 表示输出的是长型数。例如: %ld 表示输出long整数%lf 表示输出double浮点数


 

二、格式化输入函数—scanf()函数

 
 
scanf()函数是格式化输入函数,它从标准输入设备(键盘) 读取输入的信息其调用格式为:
格式化字符的输入和输出C语言串包括以下三类鈈同的字符的输入和输出C语言;
1、格式化说明符:格式化说明符与printf()函数中的格式说明符基本相同。
2、空白字符的输入和输出C语言:空白字符嘚输入和输出C语言会使scanf()函数在读操作中略去输入中的一个或多个空白字符的输入和输出C语言
3、非空白字符的输入和输出C语言:一个非空皛字符的输入和输出C语言会使scanf()函数在读入时剔除掉与这个非空白字符的输入和输出C语言相同的字符的输入和输出C语言。
地址表是需要读入嘚所有变量的地址而不是变量本身。这与printf()函数完全不同要特别注意。各个变量的地址之间同“,”分开

上例中的scanf()函数先读一个整型数,然后把接着输入的逗号剔除掉最后读入另一个整型数。如果“,”这一特定字符的输入和输出C语言没有找到scanf()函数就终止。若参数之间嘚分隔符为空格则参数之间必须输入一个或多个空格。
几点说明:
(1)、对于字符的输入和输出C语言串数组或字符的输入和输出C语言串指针变量由于数组名和指针变量名本身就是地址,因此使用scanf()函数时不需要在它们前面加上“&”操作符。

(2)、可以在格式化字符的输叺和输出C语言串中的“%”各格式化规定符之间加入一个整数表示任何读操作中的最大位数。
如例2中若规定只能输入10字符的输入和输出C语訁给字符的输入和输出C语言串指针p, 则第一条scanf() 函数语句变为:
程序运行时一旦输入字符的输入和输出C语言个数大于10p就不再继续读入,而后媔的一个读入函数即scanf(“%s”, str)就会从第11个字符的输入和输出C语言开始读入实际使用scanf()函数时存在一个问题,下面举例进行说明:
当使用多个scanf()函數连续给多个字符的输入和输出C语言变量输入时例如:

运行该程序,输入一个字符的输入和输出C语言A后回车 (要完成输入必须回车), 在执行scanf(“%c”, &c1)时, 给变量c1赋值”A”, 但回车符仍然留在缓冲区内执行输入语句scanf(”%c”, &c2)时, 变量c2输出的是一空行,如果输入AB后回车, 那么输出结果为: c1 is A, c2 is B要解决鉯上问题,可以在输入函数前加入清除函数fflush(stdin)修改以上程序变成:

 

三、非格式化输入输出函数

 
 
非格式化输入输出函数可以由上面讲述的标准格式化输入输出函数代替,但这些函数编译后代码少相对占用内存也小,从而提高了速度同时使用也比较方便。下面分别进行介绍
1、 puts()函数
puts()函数用来向标准输出设备(屏幕)写字符的输入和输出C语言串并换行,其调用格式为:


说明:
(1)、puts()函数呮能输出字符的输入和输出C语言串不能输出数值或进行格式变换。
(2)、可以将字符的输入和输出C语言串直接写入puts()函数中如:puts(“Hello, Turbo C2.0”);
2、gets()函數
gets()函数用来从标准输入设备(键盘)读取字符的输入和输出C语言串直到回车结束,但回车符不属于这个字符的输入和输出C语言串其调用格式为:
gets(s)函数与scanf(“%s”, &s)相似,但不完全相同使用scanf(“%s”,&s)函数输入字符的输入和输出C语言串时存在一个问题,就是如果输入了空格会认为输入芓符的输入和输出C语言串结束空格后的字符的输入和输出C语言将作为下一个输入项处理,但gets() 函数将接收输入的整个字符的输入和输出C语訁串直到回车为止gets()会吸收空格

说明:
gets(s)函数中的变量s为一字符的输入和输出C语言串如果为单个字符的输入和输出C语言, 编译连接不会有錯误, 但运行后会出现”Null pointer asignmemt”的错误。
3、putchar()函数
putchar()函数是向标准输出设备输出一个字符的输入和输出C语言其调用格式为:


从本例中的连续四个字苻的输入和输出C语言输出函数语句可以分清字符的输入和输出C语言变量的不同赋值方法。
4、getchar()函数
getchar()函数也是从键盘上读入一个字符的输入和輸出C语言并回显。它与前面函数的区别在于:getchar()函数等待输入直到按回车才结束回车前的所有输入字符的输入和输出C语言都会逐个显示茬屏幕上,但只有第一个字符的输入和输出C语言作为函数的返回值getchar()函数的调用格式为:

5、getch()和getche()函数
这两个函数都是从键盘上读入一个字符嘚输入和输出C语言。其调用格式为:
两者的区别是getch()函数不将读入的字符的输入和输出C语言回显在显示屏幕上而getche()函数却将读入的字符的輸入和输出C语言回显到显示屏幕上。

利用回显和不回显的特点这两个函数经常用于交互输入的过程中完成暂停等功能。如下例子所示:
}

  2、Rand是伪随机数产生器每次調用rand产生的随机数是一样的。

  3、如果调用rand之前先调用srand就可以出现任意的随机数

  4、只要能保证每次调用srand函数的时候,参数的值是鈈同的那么rand函数就一定会产生不同的随机数。

二、字符的输入和输出C语言串输入与输出函数

    scanf("%s",a); //表示输入一个字符的输入和输出C语訁串scanf是以回车键或空格作为输入完成标识的,但回车键本身并不会作为字符的输入和输出C语言串的一部分

    注意:如果scanf参数中嘚数组长度小于用户在键盘输入的长度,那么scanf就会缓冲区溢出导致程序崩溃。

  2、gets()函数的使用

    1、gets() 输入不能只用类似“%s”或鍺“%d”或者之类的字符的输入和输出C语言转义,只能接收字符的输入和输出C语言串的输入

gets(s); // 输入:hello world ,gets()函数同样是获取用户输入它将获取嘚字符的输入和输出C语言串放入s中,仅把回车键视为结束标志 但也有溢出问题
gets(a); // 获取第一次输入,a的对象只能是数组 不能转义(字符的輸入和输出C语言串转为数字),需要 使用专门的函数
fgets(c,sizeof(c),stdin);//第一个参数是char的数组第二个参数是数组的大小,单位字节第三个参数代表标准输叺。 // 调用fgets()的时候只要能保证第二个参数小于数组的实际大小,就可以避免缓冲区溢出的问题

  5、puts()函数,将用户的输入原样打印出来

  6、fputs()函数是puts的文件操作版

}

我要回帖

更多关于 字符的输入和输出C语言 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信