#include
int main()
{
int a[5] = {
1, 2, 3, 4, 5 };
int *ptr = (int *)(&a + 1);
printf( "%d,%d", *(a + 1), *(ptr - 1));
return 0;
}
这道题*(a+1)简单,就是数组首元素地址+1算出来的就是2。关键是第二个题,用来存放&a的是数组指针也就是int (*)[5],但前面有个整型指针的强转,所以&a+1由下图表示。
由于ptr-1,此时已经被转化为整型指针,减一就是往前移动一个整型。也就是5.
#include
struct Test
{
int Num;
char *pcName;
short sDate;
char cha[2];
short sBa[4];
}* p;
//假设p 的值为0x100000。 如下表表达式的值分别为多少?
//已知,结构体Test类型的变量大小是20个字节
int main()
{
p = (struct Test*)0x100000;
printf("%p\n", p + 0x1); // 0x100014
printf("%p\n", (unsigned long)p + 0x1); // 0x100001
printf("%p\n", (unsigned int*)p + 0x1); // 0x100004
return 0;
}
①这里p被转化为了结构体指针,0x1是十六进制的1也是1,+1跳过一个结构体的指针的字节数也就是20,20转化为16进制加上0x100000也是就是答案了。
②这里的p被转化为整型+1就是+1。
③这里的p被转化为整型指针+1跳过4个字节。
#include
int main()
{
int a[4] = {
1, 2, 3, 4 };
int *ptr1 = (int *)(&a + 1);
int *ptr2 = (int *)((int)a + 1);
printf("%x,%x", ptr1[-1], *ptr2);
return 0;
}
地址在内存中的存储都是以小端字节序来储存的,如果有人不懂小端字节序的话可以看看这篇博客整型在内存中的存储
ptr1[-1]的意思是*(ptr1+(-1)),-1移动一个整型,也就是内存中04000000,以十六进制打印就是4。
(int)a + 1是一个整数跳过一个字节
#include
int main()
{
int a[3][2] = {
1, 3, 5 };
int *p;
p = a[0];
printf("%d", p[0]);
return 0;
}
// 输出结果是什么?
a的排列
a[0],a[1],a[2] 分别是每一行的数组名,即每一行首元素的地址p[0]相当于对a解引用答案就是1。
#include
int main()
{
int a[5][5];
int(*p)[4];
p = a;
printf("%p,%d\n", &p[4][2] - &a[4][2], &p[4][2] - &a[4][2]);
return 0;
}
p[4][2]相当于*(*(p+4)+2),两个指针相减得到是元素之间的个数也就是-4,在内存中的存储为
转化为16进制是ffffffc。
int main()
{
int aa[2][5] = {
1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
int *ptr1 = (int *)(&aa + 1);
int *ptr2 = (int *)(*(aa + 1));
printf("%d,%d", *(ptr1 - 1), *(ptr2 - 1));
return 0;
}
这道题和第三道题的思路一样,大家可以自己感受一下。
答案是10和5.
#include
int main()
{
int a[3][2] = {
(0, 1), (2, 3), (4, 5) };
int *p;
p = a[0];
printf( "%d", p[0]);
return 0;
}
// 输出结果为多少?
逗号表达式得出来的是后面那个数,所以该题答案为1。
#include
int main()
{
char *c[] = {
"work","at","alibaba"};
char**pa=a;
pa++;
printf("%s ",*pa);
return 0;
}