1. 该段代码中注意:
!x++,先计算!x,然后拿!x同a<=1做逻辑与运算,然后x++,x自增一。虽然!和++的优先级相同……Orz
2.C中printf计算参数时是从右到左压栈的,即:printf("%d,%d/n",*ptr,*(++ptr));先计算*(++ptr),ptr指针右移一位,输出指定值,然后再输出当前指向值,两个输出应该一样。
3.*(ptr++)+=123;应该拆成:*ptr = *ptr+123;ptr++;
4.unsigned char是8位无符号数,unsigned char a = 0xA5;转换成二进制为1010 0101,b=~a>>4,a先右移4位,然后取反,得:1111 0101,再转换成10进制数:b=245
5.float a = 1.0f;(int)a输出1,&a输出a所在地址,(int&)a输出浮点数a在内存中的存储方式的整数表示,是个大整数。
6.浮点数0在内存中的存储方式也是以0存在的。
7.unsigned int a = 0xFFFFFFF7;
char* b = (char*)&a;
意思是将整型指针“a”转换成char类型指针,但指向的内容不变,只是影响寻址方式
8.用一个表达式判断X是否是2的N次方。因为2的N次方分别为2、4、8、16,……转化成2进制:10、100、1000、10000……如果X-1后同X进行“与”,结果是0,那么X是2的N次方。X&(X-1)==0
9.int m;m = m&(m-1); m同(m-1)的每次“与”运算都会减少一个二进制m的“1”。
10.用表达式找出变量a、b中比较大的:
int max = ((a+b)+abs(a-b))/2
或者:
int c = a-b;
k = unsigned(c)>>(sizeof(int)*8-1);
如果k为0,则a-b为正数,a>b,如果k为1,则a-b为负数,a<b
11.对于异或:a^a = 0; 0^a = a; a^b^a = a^a^b = b
所以如果想交换a、b,可以用:
a = a^b;b = a^b;a = a^b;即:
b = (a^b)^b = a;
a = (a^b)^a = b;