code1
int func(int x){
int counter = 0;
while(x){
counter++; //每次循环,消掉x中最后一位1
x=x&(x-1);
}
return counter;
}
以上方法用于计算x的二进制表示中包含多少位1。(注意负数由补码表示,9有2位,而-9即fffffff7 1111......0111有31位)
code2
printf("%d %d\n", *p, *(++p)); //C中printf计算参数时从右向左压栈
打印的结果是两个相同整数。
code3 类型转换
void convert(float a){
cout << "========" <<endl;
cout << int(a)<<endl;
cout << &a<<endl;
cout << (int&)a<<endl;
}
int main()
{
float a = 1.0;
float b = 0.0;
convert(a);
convert(b);
return 0;
}
/*结果
========
1
0x7ffd6e52707c
1065353216
========
0
0x7ffd6e52707c
0
*/
code3中出现的类型转换int(a)和(int)a结果一样,将float型a作为参数构造成整数;
(int&)a:将从&a开始的sizeof(int)的字节转换成int型输出,在code3中的结果和浮点数在内存的表示相关。
code4 类型转换
unsigned int a = 0xFFFFFFF7;
unsigned char i = (unsigned char)a; //强转, 高位截断, 只留1字节F7
char* b = (char*)&a; //&a 是unsigned int型,强转为char型指针
printf("%08x, %08x", i, *b); //000000F7, FFFFFFF7
若变换a值:
unsigned int a = 0xFFFFFF77;
按 %08x 打印 *b 为 00000077,*(b+1)为 FFFFFFFF
若变换 a 值为 0xFFFFF777,*b 为00000077,*(b+1) 为FFFFFFF7
当char的8位数据,首位为1时,类型转换会发生补位(在格式化输出%x时,应该是发生了char型向int型的转换)。上述情况中,若a低位字节为80及其以上,打印的结果都将以FFFFFF开头。
To be continue