前言
最近朋友给我发了些反人类的程序,有点慌,感觉自己学的是假的c语言,所以找了最近遇到的几个c语言细节(坑爹)的地方分享给大家。答案知识点会在后面给上。
反猿猴题目==0x1
输出结果是什么??
typedef struct test
{
int t;
}test;
int main()
{
int buff[sizeof((test *)0)->t];
printf("%d", sizeof(buff));
system("pause");
}
反猿猴题目==0x2
int main()
{
int a = 10;
int *b = &(int&)a;
printf("%d", *b);
system("pause");
}
反猿猴题目==0x3
int main()
{
int a = 1, b = 2, c = 2, t;
while (a < b < c) { t = a; a = b; b = t; c--; }
printf("/n%d,%d,%d", a, b, c);
system("pause");
}
反猿猴题目==0x4
union MyUnion
{
char b;
char (*p)[10];
};
int main()
{
printf("%d\n", sizeof(MyUnion));
system("pause");
}
0x1解答
看到这个,我想这玩意能编译通过??
其实一直忽略了,sizeof也是一个c的运算符。而且它的操作不止sizeof(),所以按照运算符的优先顺序,int buff[sizeof((test *)0)->t]相当于int buff[int];答案为16;
sizeof(object);//sizeof(对象);
sizeof(type_name);//sizeof(类型);
sizeof object;//sizeof对象;
ox2解答
(int&)a就是*(int *)a,绕来绕去花里胡哨。答案10;
0x3解答
<运算符是从左往右进行比较比较结果是bool值,再和第三个比较。一共循环两次,答案1,2,0;
0x4解答
联合体的大小是成员中最大成员的大小,也就是指向一维数组的指针,答案4;
最后
由于是熬夜作业,博主解答的比较简单,自己多多体会,博主睡了,小命要紧。