c语⾔赋值语句逗号,C++中赋值运算符与逗号运算符的⽤法详
赋值运算符
赋值符号“=”就是赋值运算符,它的作⽤是将⼀个数据赋给⼀个变量。如“a=3”的作⽤是执⾏⼀次赋值操作(或称赋值运算)。把常量3赋给变量a。也可以将⼀个表达式的值赋给⼀个变量。
赋值过程中的类型转换
如果赋值运算符两侧的类型不⼀致,但都是数值型或字符型时,在赋值时会⾃动进⾏类型转换。
1)  将浮点型数据(包括单、双精度)赋给整型变量时,舍弃其⼩数部分。
2)  将整型数据赋给浮点型变量时,数值不变,但以指数形式存储到变量中。
3) 将⼀个double型数据赋给float变量时,要注意数值范围不能溢出。
4)  字符型数据赋给整型变量,将字符的ASCII码赋给整型变量。
5) 将⼀个int、short或long型数据赋给⼀个char型变量,只将其低8位原封不动地送到char型变量(发⽣截断)。例如
short int i=289;
char c;
c=i; //将⼀个int型数据赋给⼀个char型变量
赋值情况见图。为⽅便起见,以⼀个int型数据占两个字节(16位)的情况来说明。
6) 将signed(有符号)型数据赋给长度相同的unsigned(⽆符号)型变量,将存储单元内容原样照搬(连原有的符号位也作为数值⼀起传送)。
【例】将有符号数据传送给⽆符号变量。
#include
using namespace std;
int main( )
{
unsigned short a;
short int b=-1;
a=b;
cout<
return 0;
}
运⾏结果为
a=65535
赋给b的值是-1,怎么会得到65535呢?请看图所⽰的赋值情况。
-1的补码形式为1111111111111111(即全部16个⼆进制位均为1),将它传送给a,⽽a是⽆符号型变量,16个位全1是⼗进制的65535。如果b为正值,且在0~32767之间,则赋值后数值不变。
不同类型的整型数据间的赋值归根结底就是⼀条:按存储单元中的存储形式直接传送。
C和C++使⽤灵活,在不同类型数据之间赋值时,常常会出现意想不到的结果,⽽编译系统并不提⽰出错,全靠程序员的经验来出问题。这就要求编程⼈员对出现问题的原因有所了解,以便迅速排除故障。
复合的赋值运算符
在赋值符“=”之前加上其他运算符,可以构成复合的运算符。如果在“=”前加⼀个“+”运算符就成了复合运算符“+=”。例如,可以有
a+=3  等价于  a=a+3
x*=y+8等价于  x=x*(y+8)
x%=3  等价于  x=x%3
以“a+=3”为例来说明,它相当于使a进⾏⼀次⾃加3的操作。即先使a加3,再赋给a。同样,“x*=y+8”的作⽤是使x乘以(y+8),再赋给x。
为便于记忆,可以这样理解:
a+= b(其中a为变量,b为表达式)
a+= b (将有下划线的“a+”移到“=”右侧)
a = a +
b  (在“=”左侧补上变量名a)
注意,如果b是包含若⼲项的表达式,则相当于它有括号。如
x %= y+3
x %= (y+3)
x = x%(y+3)(不要错认为x=x%y+3)
凡是⼆元(⼆⽬)运算符,都可以与赋值符⼀起组合成复合赋值符。C++可以使⽤以下⼏种复合赋值运算符:
+=,-=,*=,/=,%=,<<=,>>=,&=,^=,|=
其中后5种是有关位运算的。
C++之所以采⽤这种复合运算符,⼀是为了简化程序,使程序精炼,⼆是为了提⾼编译效率(这样写法与“逆波兰”式⼀致,有利于编译,能产⽣质量较⾼的⽬标代码)。专业的程序员在程序中常⽤复合运算符,初学者可能不习惯,也可以不⽤或少⽤。
赋值表达式
由赋值运算符将⼀个变量和⼀个表达式连接起来的式⼦称为“赋值表达式”。它的⼀般形式为:
如“a=5”是⼀个赋值表达式。对赋值表达式求解的过程是:先求赋值运算符右侧的“表达式”的值,然后赋给赋值运算符左侧的变量。⼀个表达式应该有⼀个值。赋值运算符左侧的标识符称为“左值”(left value,简写为lvalue)。并不是任何对象都可以作为左值的,变量可以作为左值,⽽表达式a+b就不能作为左值,常变量也不能作为左值,因为常变量不能被赋值。
c语言中逗号表达式的用法出现在赋值运算符右侧的表达式称为“右值”(right value,简写为rvalue)。显然左值也可以出现在赋值运算符右侧,因⽽左值都可以作为右值。如:
int a=3,b,c;
b=a;// b是左值
c=b;// b也是右值
赋值表达式中的“表达式”,⼜可以是⼀个赋值表达式。如
a=(b=5)
下⾯是赋值表达式的例⼦:
a=b=c=5 (赋值表达式值为5,a,b,c值均为5)
a=5+(c=6)(表达式值为11,a值为11,c值为6)
a=(b=4)+(c=6) (表达式值为10,a值为10,b等于4,c等于6)
a=(b=10)/(c=2) (表达式值为5,a等于5,b等于10,c等于2)
请分析下⾯的赋值表达式:
(a=3*5)=4*3
赋值表达式作为左值时应加括号,如果写成下⾯这样就会出现语法错误:
a=3*5=4*3
因为3*5不是左值,不能出现在赋值运算符的左侧。
赋值表达式也可以包含复合的赋值运算符。如
a+=a-=a*a
也是⼀个赋值表达式。如果a的初值为12,此赋值表达式的求解步骤如下:
先进⾏“a-=a*a”的运算,它相当于a=a-a*a=12-144=-132。
再进⾏“a+=-132”的运算,它相当于a=a+(-132)=-132-132=-264。
C++逗号运算符与逗号表达式C++将赋值表达式作为表达式的⼀种,使赋值操作不仅可以出现在赋值
语句中,⽽且可以以表达式形式出现在其他语句(如输出语句、循环语句等)中。这是C++语⾔灵活性的⼀种表现。
请注意,⽤cout语句输出⼀个赋值表达式的值时,要将该赋值表达式⽤括号括起来,如果写成“cout<
C++提供⼀种特殊的运算符——逗号运算符。⽤它将两个表达式连接起来。如
3+5, 6+8
称为逗号表达式,⼜称为“顺序求值运算符”。逗号表达式的⼀般形式为:
表达式1, 表达式2
逗号表达式的求解过程是:先求解表达式1,再求解表达式2。整个逗号表达式的值是表达式2的值。如,逗号表达式
a=3*5, a*4
赋值运算符的优先级别⾼于逗号运算符, 因此应先求解a=3*5(也就是把“a=3*5”作为⼀个表达式)。经计算和赋值后得到a的值为15,然后求解a*4,得60。整个逗号表达式的值为60。
⼀个逗号表达式⼜可以与另⼀个表达式组成⼀个新的逗号表达式,如
(a=3*5, a*4), a+5
逗号表达式的⼀般形式可以扩展为:
表达式1, 表达式2, 表达式3, …, 表达式n
它的值为表达式n的值。
逗号运算符是所有运算符中级别最低的。因此,下⾯两个表达式的作⽤是不同的:
x=(a=3, 6*3)
x=a=3, 6*a
其实,逗号表达式⽆⾮是把若⼲个表达式“串联”起来。在许多情况下,使⽤逗号表达式的⽬的只是想分别得到各个表达式的值,⽽并⾮⼀定需要得到和使⽤整个逗号表达式的值,逗号表达式最常⽤于循环语句(for语句)中。
在⽤cout输出⼀个逗号表达式的值时,要将该逗号表达式⽤括号括起来,如:
cout<
C和C++语⾔表达能⼒强,其中⼀个重要⽅⾯就在于它的表达式类型丰富,运算符功能强,因⽽使⽤灵活,适应性强。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。