变量赋初值
在做变量定义的同时给变量赋以初值的方法,这种方法称为初始化。
在变量定义中赋初值的一般形式为:
类型说明符:变量1=值1,变量2=值2;
例如:int a=3;
int b,c=5;
float x=3.2,y=3f,z=0.75;
char chl='K',ch2='P';
各类数值型数据之间的混合运算
自动转换类型
变量的数据类型是可以转换的。转换的方法有两种,一种是自动转换,另一种是强制转换。自动转换发生在不同的数据类型的量混合运算时,由编译系统自动完成。自动转换遵循以下规则:
1.若参与运算量的类型不同,则先转换成同一类型,然后进行运算。
2.转换按数据长度增加的方向进行,以保证精度不降低。如int型和long型运算时,先把int量转换成long型后再进行运算。
3.所有的浮点型运算都是以双精度进行的,即使是仅含有float单精度运算的表达式,也要先转换成double型,再作运算。
4.char型和short型参与运算时,必须先转换成int型。
注:在赋值运算中,赋值号两边量的数据类型不同时,赋值号右边量的类型将转换为左边量的类型。如果右边量的数据类型长度比左边长,将丢失一部分数据,这样会降低精度,丢失的部分将四舍五入向前舍入。
例:
#include<studio.h>
void main()
{
float PI=3.14159;
int s,r=5;
s=r*r*PI;
printf("s=%d\n",s);
}
注释:在本例程序中,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<studio.h>
{
float f=5.75;
printf("(int)f=%d,f=%f\n",(int)f,f);
}
算术运算符和算术表达式
基本的算术运算符:
1.加法运算符“+”:加法运算符为双目运算符,即应有两个量参与加法运算。如:A+b,4+8具有左结合性。
2.减法运算符“-”:减法运算符为双目运算符,具有左结合性。但“-”也可作为负值运算符,此时为单目运算符,如-5,-x具有右结合性。
3.乘法运算符“*”:乘法运算符为双目运算符,具有左结合性。
4.除法运算符“/”:除法运算符为双目运算符,具有左结合性。参与运算的量均为整型时,结果也为整型,舍去小数。如果运算量中有一个是实型,则结果为双精度实型。
例1:
#include<studio.h>
void main()
{
printf("\n\n %d,%d\n",20/7,-20/7);
printf("%f,%f\n",-20.0/7,-20.0/7);
}
例2:
#include<studio.h>
void main()
{
printf("%d\n,100%3);
}
注:“%”表示取余数。
运算符的优先级:
C语言中,运算符的优先级共分为15级,1级最高,15级最低。在表达式中,优先级较高的先于优先级较低的进行运算。而在一个运算量两侧的运算符优先级相同时,则按运算符的结合性所规定的结合方向处理。
运算符的结合性:
C语言中各运算符的结合性分为两种,即左结合性(自左向右)和右结合性(自右向左)。
如:x-y+z ,y应该先和“-”号结合,执行x-y运算,然后再执行+z的运算。这种自左向右的结合方向称为“左结合性”。
如:x=y=z,由于“=”的右结合性,应先执行y=z再执行x=(y=z)运算。这种自右向左的结合方向称为“右结合性”。
自增、自减运算符:
自增1,自减1运算:自增1运算符为“++”,其功能是使变量的值自增1;自减1运算符记为
“--”,其功能是使变量的值自减1。
自增1,自减1运算符均为单目运算符,具有右结合性,有以下形式:
++i:i自增1后参与其他运算;
--i:i自减1后参与其他运算;
i++:i参与运算后,i的值再自增1;
i--:i参与运算后,i的值再自减1。
例1:
#include<studio.h>
void 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--);
}
例2:
#include<studio.h>
void main()
{
int i=5,j=5,p,q;
p=(i++)+(i++)+(i++);
q=(++j)+(++j)+(++j);
printf("%d,%d,%d,%d",p,q,l,j);
}
赋值运算符:
简单赋值运算符记为“=”,由"="连接的式子称为赋值表达式。其一般形式为:变量=表达式。
例:
x=a+b
x=sin(a)+sin(b)
y=i+j
赋值表达式的功能是计算表达式的值再赋予左边的变量。赋值运算符具有右结合性,因此:
a=b=c=5,可理解为:a=(b=(c=5))
类型转换:
如果赋值运算符两边的数据类型不相同,系统将自动进行类型转换,即把赋值号右边的类型转换成左边的类型。具体规定如下:
1.实型赋予整型,舍去小数部分。
2.整型赋予实型,数值不变,但将以浮点形式存放,即增加小数部分(小数部分的值为0)
3.字符型赋予整型,由于字符型为一个字节,而整型为四个字节,故将字符的的ASCII码放到整型量的低八位中,高八位为0,整型赋予字符型,只把低八位赋予字符量。
例:
#include<studio.h>
void main()
{
int a,b=322;
float x,y=8.88;
char c1='k',c;
a=y;
x=b;
a=c1;
c2=b;
printf("%d,%f,%d,%c",a,x,a,c2);
}
复合的赋值运算符:
在赋值符“=”之前加上其他的双目运算符可构成复合运算符。如+=,-=,*=,/=,>>=,
<<=,&=,^=,!=。
如:
a+=5;等价于a=a+5;
x*=y+7;等价于x=x*(y+7);
r%=p;等价于r=r%p;
逗号运算符和逗号表达式:
在C语言中“,”也是一种运算符,称为逗号运算符。其功能是把两个表达式连接起来组成一个表达式,称为逗号表达式。
其一般形式为:表达式1,表达式2
其求值过程是分别求两个表达式的值,并以表达式2的值作为整个逗号表达式的值。
例:
#include<studio.h>
void main()
{
int a=2,b=4,c=6,x,y;
y=(x=a+b),(b+c);
printf("y=%d,x=%d",y,x);
}
对逗号表达式的说明:
1.逗号表达式一般形式中的表达式1和表达式2可以又是逗号表达式。
如:表达式1,(表达式2,表达式3)
形成了嵌套情形。因此可以把逗号表达式扩展为以下形式:
表达式1,表达式2,……表达式N
整个逗号表达式的值等于表达式N的值
2.程序中使用逗号表达式,通常是要分别求逗号表达式内表达式的值,并不一定求整个逗号表达式的值。
3.并不是在所有出现逗号的地方都组成逗号表达式,如在变量说明中,函数参数表中逗号只是作用各变量之间的间隔符。