C语言 百分网手机站

C语言赋值运算符

时间:2020-11-24 19:31:33 C语言 我要投稿

关于C语言赋值运算符

  其一般形式为:

  变量=表达式

  例如:

  x=a+b

  w=sin(a)+sin(b)

  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;都是赋值语句,在前面各例中我们已大量使用过了。

  类型转换

  如果赋值运算符两边的数据类型不相同,系统将自动进行类型转换,即把赋值号右边的类型换成左边的类型。具体规定如下:

  实型赋予整型,舍去小数部分。

  整型赋予实型,数值不变,但将以浮点形式存放,即增加小数部分(小数部分的值为0)。

  字符型赋予整型,由于字符型为一个字节,而整型为二个字节,故将字符的ASCII码值放到整型量的低八位中,高八位为0。整型赋予字符型,只把低八位赋予字符量。

  【例3-18】

  #include

  int main(void){

  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,按ASCII码对应于字符B)。

  注意:经大家反馈,笔者发现上面的例子容易造成误解,现已对代码进行更改,更改时间 2014-07-04 09:12:45,看评论的读者请注意评论时间,不要混淆。

  更改后的代码如下:

  #include

  int main(void){

  int a,c,b=322;

  float x,y=8.88;

  char c1=k,c2;

  a=y;

  x=b;

  c=c1;

  c2=b;

  printf("a=%d, x=%f, c=%d, c2=%c ", a, x, c, c2);

  return 0;

  }

  输出结果:

  a=8, x=322.000000, c=107, c2=B

  复合的赋值运算符

  在赋值符“=”之前加上其它二目运算符可构成复合赋值符。如+=、-=、*=、/=、%=、<<=、>>=、&=、^=、|=。

  构成复合赋值表达式的一般形式为:

  变量 双目运算符=表达式

  它等效于

  变量=变量 运算符 表达式

  例如:

  a+=5 等价于 a=a+5

  x*=y+7 等价于 x=x*(y+7)

  r%=p 等价于 r=r%p

【关于C语言赋值运算符】相关文章:

1.C语言复合赋值运算符

2.C语言赋值运算符详解

3.c语言算术运算符

4.C语言条件运算符

5.C语言关系运算符

6.C语言中的运算符

7.解析C语言编程中指针赋值的实例

8.c语言位运算符的用法