题目1
#include <stdio.h>
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等价于中的这个a代表整个数组,所以&a的类型就是int(*)[5],容易得a+1指向如下图所示
*(ptr-1)则先让ptr往后走一个int大小的位置(因为ptr是int指针),再对其进行解引用
*(ptr-1)就是5
*(a+1)中的a代表的数组首元素,所以这个式子等价于a[1]
结果是
题目2
#include<stdio.h>
//在X86环境下
//假设结构体的⼤⼩是20个字节
//程序输出的结构是啥?
struct Test
{
int Num;
char *pcName;
short sDate;
char cha[2];
short sBa[4];
}*p = (struct Test*)0x100000;
int main()
{
printf("%p\n", p + 0x1);
printf("%p\n", (unsigned long)p + 0x1);
printf("%p\n", (unsigned int*)p + 0x1);
return 0;
}
首先我们要明白0x1是16进制数,对应十进制数1
也就是说上面的0x1就是1
- p+0x1等价于p+1,即p跳到一个struct Text大小后去,即当前地址加20
- p被强制转换为十六进制无符号整数,加1
- p被强制转换为无符号整型指针,这改变了p+0x1跳动的距离,变成了4(一个unsigned int的大小)
题目3
#include<stdio.h>
//小端存储,x86环境
int main()
{
int a[4]={1,2,3,4};
int*ptr1=(int*)(&a+1)
int*ptr2=(int*)((int)a+1);
printf("%x\n%x",ptr1[-1],*ptr2);
}
ptr1和上面那个有点相同啊
解引用ptr1[-1]就是4
小端存储转变后就是
题目3
#include <stdio.h>
int main()
{
int a[3][2] = { (0, 1), (2, 3), (4, 5) };
int *p;
p = a[0];
printf( "%d", p[0]);
return 0;
}
首先它这个数组初始化就等价于下面这个
int a[3][2]={1,3,5};
a[0]相当于第一行的数组名,也会被转换为第一个元素的地址
p指向了二维数组第一个元素,p[0]等价于*p,就是1
题目4
//假设环境是x86环境,程序输出的结果是啥?
#include <stdio.h>
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;
}
我们把a的地址强行赋值给p,但是p是个int(*)[4]指针,a是int(*)[5]指针,两个指针加减一个整数时跨过的区域不同,p[4][2]和a[4][2]的位置如下图蓝色区域所示
本来都应该是打印成-4的,但是第一个打印出-4的补码的十六进制表现形式
题目5
#include <stdio.h>
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;
}
题目6
#include <stdio.h>
int main()
{
char *a[] = {"work","at","alibaba"};
char**pa = a;
pa++;
printf("%s\n", *pa);
return 0;
}
pa++后变成
题目7
#include <stdio.h>
int main()
{
char *c[] = {"ENTER","NEW","POINT","FIRST"};
char**cp[] = {c+3,c+2,c+1,c};
char***cpp = cp;
printf("%s\n", **++cpp);
printf("%s\n", *--*++cpp+3);
printf("%s\n", *cpp[-2]+3);
printf("%s\n", cpp[-1][-1]+1);
return 0;
}
第一句
第二句