1.逻辑运算符与逻辑表达式
逻辑运算符!、&&、ll依次为逻辑非、逻辑与、逻辑或,这和数学上的与、或、非是一致的.逻辑非的优先级高于算术运算符,逻辑与和逻辑或的优先级低于关系运算符.逻辑表达式的值只有真和假,对应的值为1和0,下例中的代码是计算一年是否为闰年的例子,因为需要重复测试,所以我们用了一个while循环。
针对代码中的逻辑非,首先给变量j赋值10,因为j的值非0,所以!j的值为0;然后,由于逻辑非是单目运算符,结合顺序为从右至左,得到!lj的值为1.也就是说,对0取非,得到的值为1;对非О值取非,得到的值为0.
代码例子:闰年的判断
#include <stdio.h>
#include <stdlib.h>
int main()
{
int i=O,j=1;
while(scanf("%d" ,&i))(
if(i%4==0 && i%100!=O |li%400==O){
printf("i is leap year\n");}elsef
printf("i is not leap year\n");
}
}
代码例子:逻辑非自右向左运算
#include <stdio.h>
#include <stdlib.h>
int main()
{
i=!!j;
printf("i的值=%d\n",i);return 0;
}
代码例子:短路运算
#include <stdio.h>
int main()
{
int i=o;
i&&printf("you can't see me\n");
return o;
}
逻辑与短路运算是当前面一个表达式为假时,后面的表达式不会得到执行,逻辑或短路运算是当前面一个表达式为真时,后面的表达式不会得到执行。
有的时候我们不想写if(i)的时候,可以这么书写
2.赋值运算符
2.1 左值和右值
为了理解有些操作符存在的限制,必须理解左值 (L-value)和右值 (R-value)之间的区别.这两个术语多年前由编译器设计者创造并沿用至今,尽管它们的定义与C语言并不严格吻合.
左值是那些能够出现在赋值符号左边的东西,右值是那些可以出现在赋值符号右边的东西.例如
a=b +25;
其中, a是一个左值,因为它标识了一个可以存储结果值的地点; b+25是一个右值,因为它指定了一个值.
它们可以互换吗?比如下面这种写法:
b + 25 = a;
因为每个位置都包含一个值,所以原先用作左值的a此时也可以作为右值;然而, b+25不能作为左值,因为它并未标识一个特定的位置(并不对应特定的内存空间).因此,上面这条赋值语句是非法的.
一条错误的代码样例,会报错
#include<stdio.h>
int main()
{
int a=1,b=2;
b+25=a;
return 0;
}
上面的例子执行时会报下面的编译错误
2.2 复合赋值运算符
复合赋值运算符操作是一种缩写形式,使用复合赋值运算符能使对变量的赋值操作变得更加简洁。例如.
iNum = iNum + 5;
赋值运算符与复合赋值运算符的区别如下:
(1)复合赋值运算符简化了程序,可使程序精炼,提升阅读速度。(2)复合赋值运算符提高了编译效率。
下例说明了加后赋值与乘后赋值的用法。
【例】加后赋值与乘后赋值的用法。
#include <stdio.h>#include <stdlib.h>
int main()
{
int iNum,iResult;
iNum=10;
iResult=3;
iNum+=5;
iResult*=iNum;
printf( "iNum=%d\n",iNum);
printf(" iResult=%d\n",iResult);
}
从上面的程序代码可以看到,iNum+=5代表iNum加5后再赋值给iNum,因此iNum的最终值为15,而 iResult的值等于其自身乘以iNum 的值,所以最终结果为45.
3.求字节运算符sizeof
很多人会认为sizeof是一个函数,这种理解是错误的,实际sizeof是一个运算符,不像其他运算符是一个符号,sizeof是字母组成的,用于求常量或变量所占用的空间大小,请看下例:
#include <stdio.h>
int main()
{
int i=0;
printf(""i size is %d\n",sizeof(i));
return O;
}
运行结果为i size is 4,可以求得整型变量占用的空间大小是4个字节。