欢迎访问文稿网!

赋值运算符的运算规则

范文之家 分享 时间: 加入收藏 我要投稿 点赞

赋值运算符的运算规则

    1.赋值运算符

    简单赋值运算符和表达式:简单赋值运算符记为 “=”;由 “=”连接的式子称为赋值表达式。其一般形式为:

    变量=表达式

    例如:

    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;

    都是赋值语句,在前面各例中已大量使用过了。

    2.类型转换

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

    ①实型赋予整型,舍去小数部分。前面的例子已经说明了这种情况。

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

    ③字符型赋予整型,由于字符型为1字节,而整型为2字节,故将字符的ASCII码值放到整型量的低八位中,高八位为0。整型赋予字符型,只把低八位赋予字符量即可。

    【例3.25】

    main()

    {inta,b=322;

    floatx,y=8.88;

    charc1='k',c2;

    a=y;

    x=b;

    a=c1;

    c2=b;

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

    }

    本例表明了上述赋值运算中类型转换的规则。a为整型,赋予实型量y值8.88后,只取整数8。x为实型,赋予整型量b值322后,增加了小数部分。字符型量c1赋予a变为整型,整型量b赋予c2后,取其低八位成为字符型 (b的低八位为01000010,即十进制66,按ASCII码对应于字符B)。

    【例3.26】有以下定义语句:

    doublea,b;intw;longc;

    若各变量已正确赋值,则下列选项中正确的表达式是 ( )。

    A.a=a+b=b++ B.w%((int)a+b)

    C.(c+w)%(int)a D.w=a==b;

    本例是一个综合考查运算符、强制类型转换及赋值运算的题目,答案为C。

    3.复合赋值运算符

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

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

    变量 双目运算符=表达式

    它等价于

    变量=变量运算符表达式

    例如:

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

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

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

    复合赋值符这种写法,初学者可能不习惯,但其十分有利于编译处理,能提高编译效率,并产生质量较高的目标代码。

    【例3.27】有以下程序:

    main()

    {inta;charc=10;

    floatf=100.0;doublex;

    a=f/=c*=(x=6.5);

    printf("%d %d %3.1f %3.1f\n",a,c,f,x);

    }

    程序运行后的输出结果是 ( )。

    A.1 65 1 6.5 B.1 65 1.5 6.5

    C.1 65 1.0 6.5 D.2 65 1.5 6.5

    答案为B。

221381
领取福利

微信扫码领取福利

微信扫码分享