第4章-键盘输入和屏幕输出_第1页
第4章-键盘输入和屏幕输出_第2页
第4章-键盘输入和屏幕输出_第3页
第4章-键盘输入和屏幕输出_第4页
第4章-键盘输入和屏幕输出_第5页
已阅读5页,还剩31页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第4章键盘输入和屏幕输出

数据输入输出的概念

及在C语言中的实现(一).所谓输入输出是以计算机主机为主体而言的输出:从计算机向外部输出设备(显示器,打印机)

输出数据输入:从输入设备(键盘,鼠标,扫描仪)向计算机输入数据.(二).C语言本身不提供输入输出语句,输入和输出操作是由C函数库中的函数来实现的例如:字符输入函数:getchar字符输出函数:putchar格式输入函数:scanf格式输出函数:printf字符串输入函数:gets字数穿输出函数:puts(三).在使用系统库函数时,要用预编译命令“#include”将有关的“头文件”包括到用户源文件中。例如:在调用标准输入输出库函数时,文件开头应该有:#include“stdio.h”

或:#include<stdio.h>Devc++环境下还要包含:conio.h头文件4.1字符数据的输入输出4.2简单的格式输入输出4.3较复杂格式的输入输出4.1字符数据的输入输出

4.1.1用putchar函数输出一个字符

putchar函数(字符输出函数)的作用是向终端输出一个字符。一般形式为putchar(c)c可以是字符型变量或整型变量例4.1输出单个字符。

#include<stdio.h>

voidmain()

{

chara,b,c;

a=‘B’;b=‘O’;c=‘Y’;

putchar(a);putchar(b);putchar(c);putchar(‘\n’);

}

运行结果:BOYputchar(a);putchar(‘\n’);putchar(b);putchar(‘\n’);putchar(c);putchar(‘\n’);运行结果:BOY4.1.2用getchar函数输入一个字符

getchar函数(字符输入函数)的作用是从计算机终端输入一个字符。

getchar函数没有参数,一般形式为

getchar()函数的值就是从输入设备得到的字符例4.2输入单个字符。

#include<stdio.h>

intmain()

{

charc;

c=getchar();

putchar(c);

putchar(‘\n’);return0;

}

4.2简单的格式输入与输出

4.2.1用简单的printf函数输出数据printf函数(格式输出函数)的作用是向终端(或系统隐含指定的输出设备)输出若干个任意类型的数据

。printf函数的一般格式为:

printf(格式控制,输出表列)例:

printf(”%d,%c\n”,i,c)printf函数的参数包括两部分:

(1)“格式控制”是用双撇号括起来的字符串,也称“转换控制字符串”,它包括两种信息。

①格式说明。格式说明由“%”和格式字符组成,如%d、%f等。它的作用是将输出的数据转换为指定的格式输出。格式说明总是由“%”字符开始的。②普通字符。普通字符即需要原样输出的字符。例如上面printf函数中双撇号内的逗号、空格和换行符。

(2)“输出表列”是需要输出的一些数据,可以是常量、变量或表达式。

printf函数的例子:

printf(“a=%db=%d”,a,b)若a=3,b=4输出为a=3b=4基本的格式字符有以下几种:

⑴d格式符。按十进制整型数据的实际长度输出。

⑵i格式符。作用与d格式符相同,按十进制整型数据的实际长度输出。一般习惯用%d而少用%i。⑶c格式符。用来输出一个字符。

一个值在0~255范围内的整数,也可以用“%c”使之按字符形式输出例4.3字符数据的输出。

#include<stdio.h>

voidmain()

{charc='a';

inti=97;

printf("%c,%d\n",c,c);

printf("%c,%d\n",i,i);

}运行结果:a,97a,97

⑷s格式符,用来输出一个字符串。

例:

printf(″%s″,″CHINA″);

输出字符串“CHINA”(不包括双引号)⑸f格式符。用来输出实数(包括单、双精度),以小数形式输出,不指定整个字段的长度,由系统自动指定。一般的处理方法是:整数部分全部输出,并输出6位小数。

注意:在输出的数字中并非全部数字都是有效数字。单精度实数的有效位数一般为6-7位,双精度实数的有效位数一般为15-16位。例4.4输出实数时的有效位数。

#include<stdio.h>

voidmain()

{floatx,y;

x=111111.111;y=222222.222;

printf("%f\n",x+y);

}运行结果:333333.328125结果中只有前七位是有效数字。由于x和y是单精度变量,所以x+y也只能保证7位的精度,后面几位是没有意义的。

例4.5输出双精度数时的有效位数。

#include<stdio.h>

voidmain()

{doublex,y;

x=11111111.11111111;

y=22222222.22222222;

printf("%f\n",x+y);

}运行结果:33333333.333333x和y是双精度变量,能提供16位精度,但是由于用%f格式输出,只能输出6位小数,有两位被省掉了。(6)e格式符,用格式说明%e指定以指数形式输出实数。

例:printf(″%e″,123.456);输出如下

1.23460

e+002

6列5列C编译系统自动指定给出数字部分的小数位数为6位,指数部分占5位4.2.2用简单的scanf函数输入数据scanf函数作用:按照变量在内存的地址将变量值存进去。一般格式:scanf(格式控制,地址表列)同printf函数是由若干个地址组成的表列,可以是变量的地址,或字符串的首地址例4.6用scanf函数输入数据。

#include<stdio.h>

voidmain()

{

inta,b,c;

scanf(“%d%d%d”,&a,&b,&c);

printf(“%d,%d,%d\n”,a,b,c);

}

运行情况:

345(输入a,b,c的值,)

3,4,5(输出a,b,c的值)a在内存中的地址&是地址运算符scanf函数的格式说明与printf函数的相似,以%开始,以一个格式字符结束,中间可插入附加的字符。

例:scanf(”%d%d%d”,&a,&b,&c);/*格式控制字符串中包含3个格式说明符%d*/scanf(”a=%db=%dc=%d”,&a,&b,&c);/*格式控制字符串中包含格式说明符以外的字符*/说明:scanf函数中的“格式控制”后面应当是变量地址,而不应是变量名。(2)如果在“格式控制”字符串中除了格式说明以外还有其他字符,则在输入数据时在对应位置应输入与这些字符相同的字符。(3)在用“%c”格式输入字符时,空格字符和“转义字符”都作为有效字符输入。(4)在输入数据时,空格,“回车”、“跳格”(Tab)键或遇非法输入,认为该数据结束。(5)对unsigned型变量所需的数据,可以用%u或%d格式输入。4.3较复杂的格式输入与输出

4.3.1输出数据格式控制除了上节所介绍的基本的格式控制外,还可以用下面一些格式符和附加字符。⑴%md。m为指定的输出字段的宽度。如果数据的位数小于m,则左端补以空格,若大于m,则按实际位数输出。例:printf(“%4d,%4d,a,b”);

若:a=123,d=12345,则输出结果为:123,12345⑵%ld。对于int型数据占2字节的系统,在输出长整型数据时要在格式字符d前面加一个英文字毋l。例:

longa=135790;/*定义a为长整型变量*/printf(“%ld”,a);%d只适用于范围为-32768~32767的整型数据,超过此范围的整数,应该用%ld输出说明:如果用的是VC++6.0,由于int型和long型数据都分配4个字节,因此用%d可以输出int和long型数据,不必要用%ld。

⑶%o。以8进制整数形式输出。由于是将内存单元中的各位的值(0或1)按八进制形式输出,因此输出的数值不带符号,即将符号位也一起作为八进制数的一部分输出。例:inta=-1;printf("%d,%o",a,a);

-1在内存单元中的存放形式(以补码形式存放)如下:输出为:

-1,1777771111111111111111用%d输出的结果1,111,111,111,111,111||||||177777二进数111就是8进数7。因此上面的数用8进制数表示为17777⑷%x。以16进制数形式输出整数。同样不会出现负的十六进制数。例:

inta=-1;printf(“%x,%o,%d”,a,a,a);

输出结果为

ffff,177777,-1

同样可以用“%1x”输出长整型数,也可以指定输出字段的宽度,如“%12x”。⑸%u。用来输出无符号(unsigned)型数据,以十进制整数形式输出。一个有符号整数(int型)也可以用%u格式输出;反之,一个unsigned型数据也可以用%d格式输出。按相互赋值的规则处理。unsigned型数据也可用%o或%x格式输出。

⑹%mc。用来指定输出字符数据的宽度m

如果有printf(“%3c”,c);

则输出“a”,即c变量输出占3列,前2列补空格。例4.7无符号数据的输出。

#include<stdio.h>

voidmain()

{

unsignedinta=65535;intb=-2;

printf(“a=%d,%o,%x,%u\n”,a,a,a,a);

printf(“b=%d,%o,%x,%u\n”,b,b,b,b);

}

TurboC2.0环境下的运行结果:

a=-1,177777,ffff,65535

b=-2,177776,fffe,65534VC++6.0环境下的运行结果:

a=65535,177777,ffff,65535

b=-2,37777777776,fffffffe,4294967294⑺%ms,指定输出的字符串占m列。如果字符串本身长度大于m,则突破m的限制,将字符串全部输出。若串长小于m,则左补空格。

%-ms,如果串长小于m,则在m列范围内,字符串向左靠,右补空格。

%m.ns,输出占m列,但只取字符串中左端n个字符。这n个字符输出在m列的右侧,左补空格。

%-m.ns,其中m、n含义同上,n个字符输出在m列范围的左侧,右补空格。如果n>m,则m自动取n值,即保证n个字符正常输出。⑻%m.nf,指定输出的实数共占m列,其中有n位小数。如果数值长度小于m,则左端补空格。

%-m.nf与%m.nf基本相同,只是使输出的数值向左端靠,右端补空格。例4.8字符串的输出。

#include<stdio.h>

voidmain()

{

printf(“%3s,%7.2s,%.4s,%-5.3s\n”,“CHINA”,“CHINA”,“CHINA”,“CHINA”);

}

运行结果:

CHINA,CH,CHIN,CHI例4.9输出实数时指定小数位数。

#include<stdio.h>

voidmain(){

floatf=123.456;

printf(“%f,%10f,%10.2f,%.2f,%-10.2f\n”

,f,f,f,f,f);

运行结果:

123.456001123.456001123.46123.46123.46

(9)%m.ne和%-m.ne。m、n和“-”字符的含义与前相同。此处n指拟输出的数据的小数部分(又称尾数)的小数位数。(10)%g,用来输出实数.

它根据数值的大小,自动选f格式或e格式(选择输出时占宽度较小的一种),且不输出无意义的零。

说明:除了X,E,G外,其他各式字符必须用小写。可以在printf函数中的“格

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论