C语言-数据类型(2)

变量赋初值

在做变量定义的同时给变量赋以初值的方法,这种方法称为初始化。

在变量定义中赋初值的一般形式为:

类型说明符:变量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.并不是在所有出现逗号的地方都组成逗号表达式,如在变量说明中,函数参数表中逗号只是作用各变量之间的间隔符。

 

 

 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值