C语言运算符和表达式(二)
谨记
当你还在原地停留不动时,你的敌人已经前进一大步了;当你还沉浸在成功的喜悦中,你的对手又更上一层楼了;当你还在失落无助的时候,你的敌人已经站起来继续向前走了;人生苦短,你需要不断的前行,不断的奋斗,如果哪天你真的走不动了,希望你自己不要后悔,远方的你还在看着现在的你。
本篇文章继续抒写上篇文章未写完的知识点,本篇文章讲介绍赋值运算符和表达式、sizeof()、逗号运算符和表达式、条件运算符(三目运算)。
赋值运算符和表达式
1、赋值运算符
(1)单纯赋值运算符“=”
在前面的讲解中,读者已多次看到了符号“=”。在C语言中,“=”不是等号,而是赋值运算符,它是个双目运算符,结合性是从右向左,其作用是将赋值号“=”右边的操作数赋给左边的操作数。
例如: x = 20; y = 30;
(2)复合赋值运算符“+=”、“−=”、“*=”、“/=”
在赋值符“=”之前加上其他运算符,即构成复合的运算符。C语言规定有10种复合赋值运算符,“%=”、“<<=”、“>>=”、“&=”、“^=”和“|=”,这些将在后面位运算中介绍。如图表1-1。
2、赋值表达式
用赋值运算符将一个变量和一个表达式连接起来,就成了赋值表达式。一般形式如下:
<变量名><赋值运算符><表达式> 即:变量 = 表达式
对赋值表达式求解的过程是,将赋值运算符右侧的“表达式”的值赋给左侧的变量。赋值表达式的值就是被赋值的变量的值,如“a = 10”这个赋值表达式的值是10。
3、特殊的赋值运算——自增自减运算符
“++”是自增运算符,它的作用是使变量的值增加1。“−−”是自减运算符,其作用是使变量的值减少1,例如:
i = i+1
这个赋值表达式是把变量i的值加上1后再赋给i,即将变量i的值增加1。那么在这里就可以利用自增运算符简化这个赋值表达式为
i++ 或 ++i
这里有两点需要注意。
① 自增/自减运算符仅用于变量,不能用于常量或表达式。
② 自增和自减的结合方向是自右至左。
自增和自减运算符可用在操作数之前,也可放在其后,但在表达式中这两种用法是有区别的。自增或自减运算符在操作数之前,C语言在引用操作数之前就先执行加1或减1操作;运算符在操作数之后,C语言就先引用操作数的值,而后再进行加1或减1操作。
例如:
j=i++;
其执行过程是:先将变量i的值赋值给变量j,再使变量i的值增1。结果是i的值为3,j的值为2。等价于下面两个语句:
j=i;
i=i+1;
再看以下示例:
j=++i;
其执行过程是,先将变量i的值增1,再把新i的值赋给变量j。结果是i=3,j=3。
该语句等价于下面两个语句:
i = i+1;
j=i;
3、赋值运算符中类型的转换
前面已经介绍了类型转换,当赋值运算符两边的运算对象类型不同时,将要发生类型转换,转换的规则是:把赋值运算符右侧表达式的类型转换为左侧变量的类型。具体的转换如下:
(1)浮点型与整型
将浮点数(单双精度)转换为整数时,将舍弃浮点数的小数部分,只保留整数部分。将整型值赋给浮点型变量,数值不变,只是改为浮点形式, 即小数点后带若干个0。注意:赋值时的类型转换实际上是强制的。
(2)单、双精度浮点型
由于C语言中的浮点数总是用双精度表示的,所以float 型数据只是在尾部加0延长为double型数据参加运算,然后直接赋值。double型数据转换为float型时,通过截尾数来实现,截断前要进行四舍五入操作。
(3)char型与int型
int型数值赋给char型变量时,只保留其最低8位,高位部分舍弃。
char型数值赋给int型变量时,一些编译程序不管其值大小都作正数处理,而另一些编译程序在转换时,若char型数据值大于127,就作为负数处理。对于使用者来讲,如果原来char型数据取正值,转换后仍为正值;如果原来char型值可正可负,则转换后也仍然保持原值,只是数据的内部表示形式有所不同。
(4)int型与long型
long型数据赋给int型变量时,将低16位值送给int型变量,而将高16 位截断舍弃。(这里假定int型占两个字节)。 将int型数据送给long型变量时,其外部值保持不变,而内部形式有所改变。
(5)无符号整数
将一个unsigned型数据赋给一个占据同样长度存储单元的整型变量时(如:unsigned→int、unsigned long→long,unsigned short→short) ,原值照赋,内部的存储方式不变,但外部值却可能改变。
将一个非unsigned整型数据赋给长度相同的unsigned型变量时,内部存储形式不变,但外部表示时总是无符号的。
逗号运算符和表达式
C语言中逗号“,”也是一种运算符,称为逗号运算符。其功能是把两个表达式连接起来组成一个表达式,其一般形式如下。
表达式1,表达式2
其求值过程是分别求两个表达式的值,并以表达式2的值作为整个逗号表达式的值。
对于逗号运算符需要说明3点:
① 逗号表达式一般形式中的表达式1和表达式2也可以是逗号表达式。例如“表达式1,(表达式2,表达式3)”。这样就形成了嵌套情形。
因此可以把逗号表达式扩展为以下形式“表达式1,表达式2,……,表达式n”,整个逗号表达式的值等于表达式n的值。
② 程序中使用逗号表达式,通常是要分别求逗号表达式内各表达式的值,并不一定要求整个逗号表达式的值。
③ 并不是在所有出现逗号的地方都组成逗号表达式,如在变量说明中,函数参数表中逗号只是用作各变量之间的间隔符。
int main(int argc, const char * argv[]) {
@autoreleasepool {
int x = 10, y = 15,z = 0;
z = (x + 10,y + 10);
printf("%d\n",z);
}
return 0;
}
输出结果:25
Program ended with exit code: 0
sizeof运算符
sizeof是一个单目运算符,它的运算对象是变量或数据类型,运算结果为一个整数。运算的一般形式如下:
sizeof(<类型或变量名>)
说明:它只针对数据类型,而不针对变量!
若运算对象为变量,则所求的结果是这个变量占用的内存空间字节数;若运算对象是数据类型,则所求结果是这种数据类型的变量占用的内存空间字节数。
int main(int argc, const char * argv[]) {
@autoreleasepool {
struct stuct {
char *name;
int a[10];
int b;
}stu;
int a = 10;
double b = 30;
float c = 5;
char d = 'a';
printf("a bytes %lu\n",sizeof(a));
printf("b bytes %lu\n",sizeof(b));
printf("c bytes %lu\n",sizeof(c));
printf("d bytes %lu\n",sizeof(d));
printf("stu bytes %lu\n",sizeof(stu));
}
return 0;
}
输出结果:
a bytes 4
b bytes 8
c bytes 4
d bytes 1
stu bytes 56
Program ended with exit code: 0
条件运算符
条件运算符(?)是C语言中唯一一个三目运算符,它可以提供如if-then-else语句的简易操作,其运算的一般形式如下。
<表达式1> ? <表达式2> : <表达式3>
操作符“?”作用是这样的:先计算表达式1的逻辑值,如果其值为真,则计算表达式2,并将数值结果作为整个表达式的数值;如果表达式1的逻辑值为假,则计算表达式3,并以它的结果作为整个表达式的值,
条件运算符的优先级高于赋值运算符,读者可以自行分析一下以下语句的含义。
max = (a>b)?a:b
由于条件运算符的优先级高于赋值运算符,因此,先计算赋值语句的右边部分。
当a大于b为真(即a大于b)时,条件表达式的值为a;当a大于b为假(即a大于b不成立)时,条件表达式的值为b。因此,max变量的值就是a和b中较大的值(若a与b相等时取b)。
相当于下面的语句:
if (a > b)
max = a;
else
max = b;
有一个面试题:写一个标准的比较两个数大小取大的数的一个宏定义。
#define max a > b ? a : b
总结
这篇文章介绍了很多知识点,例子虽然没有举的不多,但是确实精华,希望读者自己下来多去联系,俗话说的好“师傅领进门,修行靠自己”。
结尾
最后,希望读者在读文章的时候发现有错误或者不好的地方,欢迎留言,我会及时更改,感谢你的阅读和评论已经点赞收藏。