十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
在C语言中,输入输出函数有着相当重要的地位,它是我们的程序与用户交互的唯一途径,现在我就将C语言中比较常见的几个输入输出函数介绍给大家,以下这些讲解都是针对VC调试平台。
为安源等地区用户提供了全套网页设计制作服务,及安源网站建设行业解决方案。主营业务为成都网站建设、做网站、安源网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!
(一) 格式化输入输出函数
(1)scanf( )格式化输入函数
格式输入函数scanf( )函数,它的格式为scanf(“格式字符串”,输入列表)。“格式字符串”包含三种类型的字符:a、格式字符,以%开头的字符,用以说明输入列表的数据以何种类型及格式的形式输入。b、普通字符,要求在输入时必须原样一起输入的字符。C、空白字符(空格、跳格键、回车键)作为相邻两个数据的默认分隔符。
在scanf( )函数中有以下地方需要注意:
[1] 在scanf()函数中的格式字符串不存在转义字符,所以:格式字符串中的字符除了格式字符外全部都要原样输入。
如:
int a;
scanf(“%d\n”,a);如果我们想把10赋值给a,就需要在键盘上输入的是:
10\n回车,才能把10赋值给a,这里\n已经不是转义字符,而是普通字符。
[2] 输入列表的变量如果是基本类型(即整型、实型、字符型)一定要使用取地址符(输入字符串到字符数组的情况除外),而且后必须是变量,不允许是常量或表达式。
如:
int a,b;
scanf("%d%d",a,b); 这是不合法的。Scanf函数的作用是:按照a、b在内存的地址将a、b的值存进去。“a”指a在内存中的地址。
[3] 输入数据时,企图规定精度
float a;
scanf("%.2f",a);
这样做是不合法的,输入数据时不能规定精度,这里要记住一个程序是不能控制操作它的人来输入数据的精度的。
[4] 输入数据的方式与要求不符
① scanf("%d%d",a,b);
输入时,不能用逗号作两个数据间的分隔符,如下面输入不合法:3,4 输入数据时,在两个数据之间以一个或多个空格间隔,也可用回车键,跳格键tab。
②scanf("%d,%d",a,b);
C规定:如果在“格式控制”字符串中除了格式说明以外还有其它字符,则在输入数据时应输入与这些字符相同的字符。下面输入是合法的:3,4
此时不用逗号而用空格或其它字符是不对的。3 4
又如:scanf("a=%d,b=%d",a,b);
输入应如以下形式:a=3,b=4
[5] 输入字符的格式与要求不一致
在用“%c”格式输入字符时,“空格字符”和“转义字符”都作为有效字符输入。
scanf("%c%c%c",c1,c2,c3);
如输入a b c
字符“a”送给c1,字符“ ”送给c2,字符“b”送给c3,因为%c只要求读入一个字符,后面不需要用空格作为两个字符的间隔。
[6] 使用格式字符”%c”录入单个字符时,空格和回车键等字符都会作为有效字符输入,所以需要注意fflush(stdin)的使用。
[7] 注意输入列表中的元素的个数要与格式字符串中的格式字符个数相同。
[8] 在输入长整形数据和双精度浮点数时,必须使用长度修饰符”l”。
[9] 不要在不该使用取地址符的地方使用取地址符。
如:char str[10];
Scanf(%c,str);这里不应该加取地址符。
(2)printf( )格式输出函数
格式输出函数printf( ),它的格式为printf(“格式字符串”,输出列表)。这里的格式字符串也包含三种类型的字符,但这里和scanf( )函数的字符稍有不同。这三种类型的字符分别是:a、格式字符,以%开头的字符,用以说明输出列表的数据以何种格式的形式输出。B、转义字符,提供特殊的格式化控制,由一个“\”和一个字符组成。反斜杠会使printf( )函数以特殊的方式解释一个字符。C、普通字符,除格式字符和转义字符外的其他字符。
在printf( )函数中有以下地方需要注意:
[1] 输出列表由若干个输出项组成,输出项可以是常量、变量,也可以是表达式。
[2] 格式字符串中的格式字符要与后边输出列表中的元素类型一一对应。
如:
float a=1.9999;
printf("%d",a);最终的输出结果是一些乱码。
再如:
int a=12;
printf("%f",a);最终的输出结果是0.000000,这里没有进行类型转换。
但是,如果想把上面的整数a以浮点数的形式输出,必须进行强制类型转换。如:
int a=12;
printf("%f",(float)a);输出的结果是12.000000。
[3] 格式字符串中的格式字符的个数要与输出列表中的元素个数相同。
如:
int a=12;
printf("%d, %d",a);将在屏幕上输出一个12以及一个乱码。
[4] 在以%.nf这样的格式进行输出浮点数时,有四舍五入。
如:
float a=1.9999;
printf(“%.2f”,a);最终的输出结果是2.00。
[5] 长度修饰符“l”在输出长整形数据时可不要,因为在VC中,long和int占用的字节长度都是4,所有可以不加上“l”。
[6] 格式符%±nd中,n表示一个十进制整数输出时在屏幕上占n个字符的宽度,如果n前面是+号,则表示输出的整数右对齐,那么输出的整数左边补空格;如果n前面是-号,则表示输出的整数左对齐,输出的整数右边补空格。
[7] 在-128~127之间的整数可以以字符的格式输出,字符也可以以整型的格式输出。
如:
int a=97;
printf("%c",a);输出的结果是’a’,因为‘a’存储在内存中是以ASCII码的形式存储的。
再如:
char a='a';
printf("%d",a);输出的结果是97,原因同上。
(二) 单字符输入、输出函数
C语言提供了两个无格式控制的,专门用于输入、输出单个字符的函数getchar( )和putchar( )。
(1) 单字符输入函数getchar( )
[1] getchar( )函数没有参数,有返回值,返回的就是输入的那个字符。
[2] getchar( )函数一次只能接收一个字符。
[3] getchar( )函数同样将空格和回车键等字符都会作为有效字符输入,所以注意和fflush(stdin)函数的结合使用。
(2) 单字符输出函数putchar( )
[1] putchar()函数有参数,无返回值。参数就是它要输出的那个字符,可以是字符变量或着字符常量
[2] putchar()函数一次向显示器输出一个字符。
(三) 字符串输入、输出函数
C语言还提供了两个无格式控制的专门对字符串处理的函数,gets( )和puts( )。
(1) gets( )用来接收用户输入的字符串,这是个有参数的函数,参数是一个字符数组类型,输入的字符串通过传址的方式传到这个字符数组中。
(2) puts()用来向用户显示一个字符串,它需要一个字符串参数,显示该参数并自动换行。
如:
puts(“hello, world.”);与printf(“hello,world.\n”);的效果相同,如果是puts(“hello.world.\n”)则要输出两个换行。也就是说,puts( )中的字符串可以包含转义字符。
输入字符串:
scanf("%s",in_buff);
——可以格式化输入;第二个参数是地址,可以是字符指针或者字符数组;不提供字符数组数据越界检查;以回车结束输入。
gets(in_buff);
——参数为地址,可以使字符指针或者字符数组;不提供字符数组越界检查;以回车结束输入。
fgets(in_buff,BUFFER_SIZE + 1,stdin);
——参数1为字符指着或者字符数组,参数2为要输入的字符个数,+1表示字符串结束标志,参数3为标准是输入;提供越界检查,以buffer_size+1为标准;以回车结束输入。
输入字符:
getch();
——从控制台读取一个字符,但是不回显在屏幕上;不需要回车结束。
getche();
——从控制台读取一个字符,回显屏幕;不需要回车结束。
getchar();
——从控制台读取一个字符,回显屏幕;需要回车结束(如果连续使用该函数,要注意下次调用该函数,会读取上次输入的回车符)。
scanf("%c",char *);
——从控制台读取一个字符,回显屏幕;需要回车结束(注意事项同上)。
这就是C语言中常用到的几个输入输出函数,而且这几个函数都包含在stdio.h头文件中。在这几个函数中,格式输入输出的用途最多也最容易出问题,希望提起大家的注意。
34种运算符:
01、圆括号()
02、下标[]
03、指针型结构成员-
04、结构成员.
05、逻辑非!
06、位非~
07、自增++
08、自减--
09、取负-
10、类型转换(类型)
11、取内容*
12、取地址
13、求字节sizeof
14、乘*
15、除/
16、求余%
17、加+
18、减-
19、左移
20、右移
21、小于
22、小于等于=
23、大于
24、大于等于=
25、等于==
26、不等于!=
27、位与
28、位异或^
29、位或|
30、与
31、或||
32、条件运算?:
33、赋值运算=
34、逗号运算,
扩展资料
9种控制语句
1、if()~else条件语句
2、for()~循环语句
3、while()~循环语句
4、do~while()循环语句
5、continue结束本次循环语句
6、break中止执行switch或循环语句
7、switch多分支选择语句
8、goto转向语句
9、return从函数返回语句
C语言输入输出函数有很多,标准I/O函数中包含了如下几个常用的函数:
scanf,printf,getc,putc,getchar,putchar,gets,puts,fgets,fputs,fgetc,fputc,fscanf,fprintf等.
int
scanf(const
char
*format,
arg_list)
scanf主要从标准输入流中获取参数值,format为指定的参数格式及参数类型,如scanf("%s,%d",str,icount);
它要求在标准输入流中输入类似"son
of
bitch,1000"这样的字符串,同时程序会将"son
of
bitch"给str,1000给icount.
scanf函数的返回值为int值,即成功赋值的个数,在上例中如果函数调用成功,则会返回2,所以我们在写程序时,可以通过
语句if(scanf("%s,%d",str,icount)
!=
2){...}来判断用户输入是否正确.
int
printf(const
char
*format,
arg_list)
printf主要是将格式化字符串输出到标准输出流中,在stdio.h头文件中定义了标准的输入和输出,分别是stdin,stdout.
arg_list可以是变量名,也可以是表达式,但最终都会以值的形式填充进format中.
int
getc(FILE
*fp)
getc主要是从文件中读出一个字符.常用的判断文件是否读取结束的语句为:(ch
=
getc(fp))
!=
EOF.EOF为文件结束标志,
定义在stdio.h中,就像EXIT_SUCCESS,EXIT_FAILURE定义在stdlib.h中一样,文件也可以被理解为一种流,所以当fp为stdin
时,getc(stdin)就等同于getchar()了.
int
putc(int
ch,FILE
*fp)
putc主要是把字符ch写到文件fp中去.如果fp为stdout,则putc就等同于putchar()了.
int
getchar(void)
getchar主要是从标准输入流读取一个字符.默认的标准输入流即stdio.h中定义的stdin.但是从输入流中读取字符时又
涉及到缓冲的问题,所以并不是在屏幕中敲上一个字符程序就会运行,一般是通过在屏幕上敲上回车键,然后将回车前的字符
串放在缓冲区中,getchar就是在缓冲区中一个一个的读字符.当然也可以在while循环中指定终止字符,如下面的语句:
while
((c
=
getchar())
!=
'#')这是以#来结束的.
int
putchar(int
ch)
putchar(ch)主要是把字符ch写到标准流stdout中去.
char
*
gets(char
*str)
gets主要是从标准输入流读取字符串并回显,读到换行符时退出,并会将换行符省去.
int
puts(char
*str)
puts主要是把字符串str写到标准流stdout中去,并会在输出到最后时添加一个换行符.
char
*fgets(char
*str,
int
num,
FILE
*fp)
str是存放读入的字符数组指针,num是最大允许的读入字符数,fp是文件指针.fgets的功能是读一行字符,该行的字符数
不大于num-1.因为fgets函数会在末尾加上一个空字符以构成一个字符串.另外fgets在读取到换行符后不会将其省略.
int
fputs(char
*str,
file
*fp)
fputs将str写入fp.fputs与puts的不同之处是fputs在打印时并不添加换行符.
int
fgetc(FILE
*fp)
fgetc从fp的当前位置读取一个字符.
int
fputc(int
ch,
file
*fp)
fputc是将ch写入fp当前指定位置.
int
fscanf(FILE
*fp,
char
*format,...)
fscanf按照指定格式从文件中出读出数据,并赋值到参数列表中.
int
fprintf(FILE
*fp,
char
*format,...)
fprintf将格式化数据写入流式文件中.
七个
+ - * / % ++ --
加减乘除不用我说了吧
"%"求余,就是算除法,值是他的余数
"/"这个是除法,但是有一点注意,两边操作数全为整数时,值是取整的。
“++”是自加,比如说i++就是i的值自动加1,规则是i++是鲜赋值再自加,++i是先自加再赋值。举个例子a=i++这个是先把i的值赋给a,然后i再自加。a=++i是i先自加,然后把自加之后的值赋给a。
“--”是自减,和自加的规则相同,只是值是自动减一。
C语言的运算符可分为以下几类:
1. 算术运算符:用于各类数值运算。包括加(+)、减(-)、乘(*)、除(/)、求余(或称模运算,%)、自增(++)、自减(--)共七种。
2. 关系运算符:用于比较运算。包括大于()、小于()、等于(= =)、大于等于(=)、小于等于(=)和不等于(!=)六种。
3. 逻辑运算符:用于逻辑运算。包括与()、或(||)、非(!)三种。
4. 位操作运算符:参与运算的量,按二进制位进行运算。包括位与()、位或(|)、位非(~)、位异或(^)、左移()、右移()六种。
5. 赋值运算符:用于赋值运算,分为简单赋值(=)、复合算术赋值(+=,-=,*=,/=,%=)和复合位运算赋值(=,|=,^=,=,=)三类共十一种。
6. 条件运算符:这是一个三目运算符,用于条件求值(?:)。
7. 逗号运算符:用于把若干表达式组合成一个表达式(,)。
8. 指针运算符:用于取内容(*)和取地址()二种运算。
9. 求字节数运算符:用于计算数据类型所占的字节数(sizeof)。
10. 特殊运算符:有括号(),下标[],成员(→,.)等几种。