上午好,本来想上午改简历下午学习c语言的,但想了一下上午精力充沛还是用来学习比较好,虽然现在失业了,但住在我姨家有吃有住的,再次感谢我姨,我要抓紧时间修改简历,然后找个工作搬出去,不能一直在我姨家住着啊。努力吧,先找个相对轻松的不加班工作过度着也可以。今天把第三章的学习输出完,然后我会把这一章的内容整理到一篇文章中,我学的内容是C语言编程宝典里的,手机端看着很方便,有兴趣的可以自己搜索去看看非广告,软件商看到了记得给我打钱嘿嘿。ok,聊天结束,开始今天的学习。
3.6变量赋初值(理解)
在程序中常常需要对变量赋初值,以便使用变量。语言程序中可有多种方法为变量提供初值。本小节先介绍在作变量定义的同时给变量赋初值的方法。这种方法称为初始化。在变量定义中赋初值的一般形式为:类型说明符 变量1=值1,变量2=值2,。。。;
例如:
int a=3;
int b,c=5;
float x=3.2,y=3f,z=0.75;
char ch1='g',ch2='p';
应注意,在定义中不允许连续赋值,如a=b=c=5是不合法的。
#include <stdio.h>
int main()
{
int a = 3,b,c = 5;
b = a+c;
printf("a=%d,b=%d,c=%d\n",a,b,c);
return 0;
}
运行结果:
3.7 各类数值型数据之间的混合运算(理解)
变量的数据类型是可以转换的。转换的方法有两种,一种是自动转换,一种是强制转换。自动转换发生在不同数据类型的量混合运算时,由编译系统自动完成。自动转换遵循以下规则:
1)若参与运算量的类型不同,则先转换成同一类型,然后进行运算。
2)转换按数据长度增加的方向进行,以保证精度不降低。如int型和long型运算时,先把int量转成long型后再进行运算。
3)所有的浮点运算都是以双精度进行的,即使仅含float单精度量运算的表达式,也要先转换成double型,再作运算。
4)char型和short型参与运算时,必须先转换成int型。
5)在赋值运算中,赋值号两边量的数据类型不同时,赋值号右边量的类型将转换为左边量的类型。如果右边量的数据类型长度左边长时,将丢失一部分数据,这样会降低精度,丢失的部分按四舍五入向前舍入。
下图表示了类型自动转换的规则。
例3.12 求圆面积
#include <stdio.h>
int main()
{
float PI = 3.14159;
int s,r = 5;
s = r*r*PI;
printf("s=%d\n",s);
return 0;
}
运行结果:
本例程序中,PI为实型;s,r为整型。在执行s=r*r*PI语句时,r和PI都转换成double型计算,结果也为double型。但由于s为整型,故赋值结果仍为整型,舍去了小数部分。
强制类型转换
强制类型转换是通过类型转换运算来实现的。
其一般形式为:
(类型说明符)(表达式)
其功能是把表达式的运算结果强制转换成类型说明符所表示的类型。
例如:
(float)a 把a转换为实型
(int) (x+y) 把x+y的结果转换为整型
在使用强制转换时应注意以下问题:
1)类型说明符和表达式都必须加括号(单个变量可以不加括号),如把(int)(x+y)写成(int)x+y则成了把x转换成int型之后再与y相加了。
2)无论是强制转换或是自动转换,都只是为了本次运算的需要而对变量的数据长度进行的临时性转换,而不改变数据说明时对该变量定义的类型。
#include <stdio.h>
int main()
{
float f = 5.75;
printf("(int)f=%d,f=%f\n",(int)f,f);
return 0;
}
运行结果:
本例表明,f虽然强制转为int型,但只在运算中起作用,是临时的,而f本身的类型并不改变。因此,(int)f的值为5(删去了小数)而f的值仍为5.75
3.8算术运算符和算术表达式(掌握)
C语言中运算符和表达式数量之多,在高级语言中是少见的。正是丰富的运算符和表达式使C语言功能十分完善。这也是C语言的主要特点之一。
C语言的运算符不仅具有不同的优先级,而且还有一个特点,就是它的结合性。在表达式中,各运算量参与运算的先后顺序不仅要遵守运算符优先级别的规定,还要受运算符结合性的制约,以便确定是自左向右进行运算还是自右向左进行运算。这种结合性是其他高级语言的运算符所没有的,因此也增加了C语言的复杂性。
3.8.1 C运算符简介(考点)
其实我一直不太懂这个考点是什么意思,可能就是c语言考试的考点吧,对我来说,了解掌握了就行
运算符优先级是C语言掌握的重难点,也是必考点。
C语言的运算符可分为以下几类:
1.算术运算符:用于各类数值运算。包括加(+)、减(-)、乘(*)、除(/)、求余(或称模运算,%)、自增(++)、自减(--)共七种。
2.关系运算符:用于比较运算。包括大于(>)、小于(<)、等于(==)、大于等于(>=)、小于等于(<=)和不等于(!=)六种。
3.逻辑运算符:用于逻辑运算。包括与(&&)、或(||)、非(!)三种。
4.位操作运算符:参与运算的量,按二进制位进行运算。包括位与(&)、位或(|)、位非(~)、位异或(^)、左移(<<)、右移(>>)六种。
5.赋值运算符:用于赋值运算,分为简单赋值(=)、复合算术赋值(+=,-=,*=,/=,%=)和复合位运算赋值(&=,|=,^=,>>=,<<=)三类共十一种。
6.条件运算符:这是一个三目运算符,用于条件求值(?:)。
7.逗号运算符:用于把若干表达式组合成一个表达式(,)。
8.指针运算符:用于取内容(*)和取地址(&)二种运算。
9.求字节数运算符:用于计算数据类型所占的字节数(sizeof)。
10.特殊运算符:有括号(),下标[],成员(->, .)等几种。
3.8.2 算术运算符和算术表达式
1.基本的算术运算符(掌握)
(1)加法运算符“+”:加法运算符为双目运算符,即应有两个量参与加法运算。如a+b,4+8等。具有右结合性。
(2)减法运算符“-”:减法运算符为双目运算符。但“-”也可作负值运算符,此时为单目运算,如-x,-5等具有左结合性。
(3)乘法运算符“*”:双目运算,具有左结合性。
(4)除法运算符“/”:双目运算具有左结合性。参与运算量均为整型时,结果也为整型,舍去小数。如果运算量中有一个是实型,则结果为双精度实型。
(5)求余运算符(模运算符)“%”:双目运算,具有左结合性。要求参与运算的量均为整型。求余运算的结果等于两数相除后的余数。
#include <stdio.h>
int main()
{
printf("\n\n%d,%d\n",20/7,-20/7);
printf("%f,%f\n",20.0/7,-20.0/7);
return 0;
}
运行结果:
本例中,20/7,-20/7的结果均为整型,小数全部舍去。而20.0/7和-20.0/7由于有实数参与运算,因此结果也为实型。
(1)重点掌握除法“/”,当两侧都为整型时,结果也为整型。如10/3=3而不是3.3...这是新手常犯错误。
(2)求余运算符“%”;两侧必须为整型,其他类型错误。为常考点。
#include <stdio.h>
int main()
{
printf("%d\n",100%3);
return 0;
}
运行结果:
出结果的时候我有点蒙,但一想到是“%”取余,就明白了。
本例输出100除以3所得的余数为1。、
2.算术表达式和运算符的优先级和结合性(理解)
表达式是由常量、变量、函数和运算符组合起来的式子。一个表达式有一个值及其类型,它们等于计算表达式所得结果的值和类型。表达式求值按运算符的优先级和结合性规定的顺序进行。单个的常量、变量、函数可以看作是表达式的特例。
算术表达式是由算术运算符和括号连接起来的式子。
(1)算术表达式:用算术运算符和括号将运算对象(也称操作数)连接起来的、符合C语法规则的式子。
以下是算术表达式的例子:
a+b
(a*2)/c
(x+r)*8-(a+b)/7
++I
sin(x)+sin(y)
(++i)-(j++)+(k--)
(2)运算符的优先级(考点):C语言中,运算符的运算优先级共分为15级。1级最高,15级最低。在表达式中,优先级较高的先于优先级较低的进行运算。而在一个运算量两侧的运算符优先级相同时,则按运算符的结合性所规定的结合方向处理。
(3)运算符的结合性:C语言中各运算符的结合性分为两种,即左结合性(自左向右)和右结合性(自右向左)。例如算术运算符的结合性是自左至右,即先左后右。如有表达式x-y+z则y应先与“-”号结合,执行x-y运算,然后再执行+z的运算。这种自左至右的结合方向就称为“左结合性”。而自右至左的结合方向就称为“右结合性”。最典型的右结合性运算符是赋值运算符。如x=y=z,由于“=”的右结合性,应先执行y=z再执行x=(y=z)运算。C语言运算符中有不少为右结合性,应注意区别,以避免理解错误。
3.强制类型转换运算符(理解)
其一般形式为:
(类型说明符)(表达式)
其功能是把表达式的运算结果强制转换成类型说明符所表示的类型。
例如:
(float)a 把a装换为实型
(int)(x+y) 把x+y的结果转换为整型
4.自增、自减运算符(重点考点)
自增1,自减1运算符:自增1运算符记为“++”,其功能是使变量的值自增1。
自减1运算符记为“--”,其功能是使变量值自减1。
自增1,自减1运算符均为单目运算,都具有右结合性。可有以下几种形式:
++i i自增1后再参与其它运算。
--i i自减1后再参与其他运算。
i++ i参与运算后,i的值再自增1。
i-- i参与运算后,i的值再自减1。
在理解和使用上容易出错的是i++和i--。特别是当它们出在较复杂的表达式或语句中时,常常难于弄清,因此应仔细分析。
#include <stdio.h>
int main()
{
int i = 8;
printf("%d\n",++i);
printf("%d\n",--i);
printf("%d\n",i++);
printf("%d\n",i--);
printf("%d\n",-i++);
printf("%d\n",-i--);
return 0;
}
运行结果:
i的初值为8,第2行i加1后输出故为9;第三行减1后输出故为8;第四行输出i为8之后再加1(为9);第5行输出i为9之后再减1(为8);第6行输出-8之后再加1(为9),第7行输出-9之后再减1(为8)。
例3.17
#include <stdio.h>
int main()
{
int i = 5,j = 5,p,q;
p=(i++)+(i++)+(i++);
q=(++j)+(++j)+(++j);
printf("%d,%d,%d,%d",p,q,i,j);
return 0;
}
运行结果:
提示:此程序由于涉及到连续++,其结果在不同的编译器有可能不同,目前已有[18,21,8,8][18,22,8,8][15,24,8,8]三种结果。在实际使用过程中,要避免此用法
很神奇,我在手机编译软件上的结果是[18,21,8,8]。先学到这一步吧,至于编译器怎么做的,让我以后再去探究。
这个程序中,对p=(i++)+(i++)+(i++)应理解为三个i相加,故p值为15。然后i再自增1三次相当于加3故i的最后值为8。而对于q的值则不然,q=(++j)+(++j)+(++j)应理解为j先自增1,再参与运算,由于j自增1三次后值为8,三个8相加的和为24,j的最后值仍为8;ps(手机软件里的也有错误的,想要学好,真的要自己用心)
3.9 赋值运算符和赋值表达式(理解)
1.赋值运算符(理解)
简单赋值运算符和表达式:简单赋值运算符记为“=”。由“=”连接的式子称为赋值表达式。其一般形式为:
变量=表达式
例如:
x=a+b
w=sin(a)+sin(b)
y=i+++--j // 这个我的理解是y=(i++)+(--j)
赋值表达式的功能是计算表达式的值再赋予左边的变量。赋值运算符具有右结合性。因此
a=b=c=5
可理解为
a=(b=(c=5))
在其它高级语言中,赋值构成了一个语句,称为赋值语句。而在C中,把“=”定义为运算符,从而组成赋值表达式。凡是表达式可以出现的地方均可出现赋值表达式。
例如,式子:
x=(a=5)+(b=8)
是合法的。它的意义是把5赋予a,8赋予b,再把a,b相加,和赋予x,故x应等于13。
在C语言中也可以组成赋值语句,按照C语言规定,任何表达式在其末尾加上分号就构成为语句。因此如
x=8;
a=b=c=5;
都是赋值语句,在前面各例中我们已大量使用过了。
// 前面3.6章变量赋初值说定义中不允许连续赋值,这里又可以。我本以为是它写错了,正在骂它,后来仔细一看,定义中不允许连续赋值,原来我才是小丑。我试过了,定义的时候会报错,调用的时候赋值不会报错,重点在“定义”两个字!
2.类型转换(理解)
如果赋值运算符两边的数据类型不相同,系统将自动进行类型转换,即把赋值号右边的类型换成左边的类型。具体规定如下:
1)实型赋予整型,舍去小数部分。前面的例子已经说明了这种情况。
2)整型赋予实型,数值不变,但将以浮点形式存放,即增加小数部分(小数部分的值为0)。
3)字符型赋予整型,由于字符型为一个字节,而整型为两个字节,故将字符的ASCLL码值放到整型量的低八位中,高八位为0。整型赋予字符型,只把低八位赋予字符量。
例3.18
#include <stdio.h>
int main()
{
int a,b = 322;
float x,y=8.88;
char c1='k',c2;
a=y;
x=b;
a=c1;
c2=b;
printf("%d,%f,%d,%c",a,x,a,c2);
return 0;
}
本例表明了上述赋值运算中类型转换的规则。a为整型,赋予实型量y值8.88后只取整数8。x为实型,赋予整型量b值322,后增加了小数部分。字符型量c1赋予a变为整型,整型量b赋予c2后取其低八位成为字符型(b的低八位为01000010,即十进制66,按ASCLL码对应于字符B)。
3复合的赋值运算符(理解)
在赋值符“=”之前加上其它二目运算符可构成复合赋值符。如+=,-=,*=,/=,%=,<<=,>>=,&=,^=,|=。
构成复合赋值表达式的一般形式为:
变量 双目运算符=表达式
它等效于
变量=变量 运算符 表达式
例如:
a+=5 等价于a=a+5
x*=y+7 等价于x=x*(y+7)
r%=p 等价于r=r%p
复合赋值符这种写法,对初学者可能不习惯,但十分有利于编译处理,能提高编译效率并产生质量较高的目标代码。
3.10 逗号运算符和逗号表达式(理解)
在c语言中逗号“,”也是一种运算符,称为逗号运算符。其功能是把两个表达式连接起来组成一个表达式,称为逗号表达式。
其一般形式为:
表达式1,表达式2
其求值过程是分别求两个表达式的值,并以表达式2的值作为整个逗号表达式的值。
例3.19
#include <stdio.h>
int main()
{
int a=2,b=4,c=6,x,y;
// 如果不加外层大括号,y=(x=a+b),(b+c);
// 那么因为'='的优先级大于',',那么就会取第一个值
y=((x=a+b),(b+c));
printf("y=%d,x=%d",y,x);
return 0;
}
运行结果:
本例中,y等于整个逗号表达式的值,也就是表达式2的值,x是第一个表达式的值。对于逗号表达式还要说明两点:
1)逗号表达式一般形式中的表达式1和表达式2也可以又是逗号表达式。
例如:
表达式1,(表达式2,表达式3)
形成了嵌套情形。因此可以把逗号表达式扩展为以下形式:
表达式1,表达式2,...表达式n
整个逗号表达式的值等于表达式n的值。
2)程序中使用逗号表达式,通常是要分别求逗号表达式内各表达式的值,并不一定要求整个逗号表达式的值。
并不是在所有出现逗号的地方都组成逗号表达式,如在变量说明中,函数参数表中逗号只是用作各变量之间的间隔符。
3.11小结
3.11.1 C的数据类型
基本类型,构造类型,指针类型,空类型
3.11.2 基本类型的分类及特点
3.11.3 常量后缀
L或l 长整型
U或u 无符号数
F或f 浮点数
3.11.4 常量类型
整数,长整数,无符号数,浮点数,字符,字符串,符号常数,转义字符。
3.11.5 数据类型转换
(1)自动转换:在不同类型数据的混合运算中,由系统自动实现转换,由少字节类型向多字节类型转换。不同类型的量相互赋值时也由系统自动进行转换,把赋值号右边的类型转换为左边的类型。
(2)强制转换:由强制转换运算符完成转换。
3.11.6 运算符优先级和结合性
一般而言,单目运算符优先级较高,赋值运算符优先级低。算术运算符优先级较高,关系和逻辑运算符优先级较低。多数运算符具有左结合性,单目运算符、三目运算符、赋值运算符具有右结合性。
3.11.7 表达式
表达式是由运算符连接常量、变量、函数所组成的式子。每个表达式都有一个值和类型。表达式求值按运算符的优先级和结合性所规定的顺序进行。
总于完成了,写了一下午加上晚上,大概有5个小时的时间。明天把这一整章节的内容合并一下,我自己看着都感觉好长,屏幕前的你呢?会不会觉得很长呢?可以的话可以给我留言,希望得到你们的建议,我每次打开博客都满怀期待的希望有人可以给我留言反馈。可到现在一个也没有(哭)还有很感谢给我点赞收藏加关注的粉丝朋友们,感谢你们的鼓励,我会继续输出下去。让我们一起变得越来越好吧!越来越好是多好呢?我也不知道,好是没有尽头的对吗朋友。就像我的名字颈部者(本来我是想取进步者的,但好像注册的时候被用了,然后我的颈椎不太好,所以我就改成了颈部者,用来提醒自己要保护颈椎,注意自己的坐姿,看到这里的朋友一定要注意自己的身体健康哦,我真的很后悔大学时候在床上买的那个懒人靠枕,以及我平常的坏习惯。我最疼的时候在床上躺着翻身都疼的要死,轻轻一动就疼的厉害,没有疼痛的人真的很难感受这种痛苦,大家引以为戒吧)
我的各种网名名字一直是进步着之类的,感觉这样是挺好的,但好像没有尽头一样,像我这种普通人,什么都进步,全方面的发展好像就是全面平庸,合适的职业和人生目标我都没有找到,但我的人生价值观就是传递爱,友爱、敬爱、喜爱、等等爱~。首先爱我的女粉丝嘿嘿,今晚随机亲一口我的女粉丝嘿嘿嘿,反正我现在没有女朋友,没事,我心安理得。
心事分享完毕,接下来休息一下眼睛,拉伸一下身体就改简历啦,不会wps的页面布局操作真是麻烦,网上的模板都要钱,潮了。