下面将继续上文章的指针笔试题,讲解8题指针笔试题2版,将会进行分析和画图讲解。如果想指针验证评估自己的指针地基是否牢固以及有兴趣的初学者,可以尝试挑战。
话不多说,边上题做边讲解
热身1
int main() {
int a[] = { 1,2,3,4,5 };
int* ptr = (int*)(&a + 1);
printf("%d,%d\n",*(a+1),*(ptr-1));
//a+1首元素地址+1,解引用得到2
//存入ptr=(&a+1)指针从1的前面跳到5的后面;ptr-1跳到5的前面;
return 0;
}
答案+图解
int main() {
int a[] = { 1,2,3,4,5 };
int* ptr = (int*)(&a + 1);
printf("%d,%d\n",*(a+1),*(ptr-1));//2,5
//a+1首元素地址+1,解引用得到2
//存入ptr=(&a+1)指针从1的前面跳到5的后面;ptr-1跳到5的前面;
return 0;
}
图解
笔试题2
struct Test
{
int Num;
char* pcName;
short sDate;
char cha[2];
short sBa[4];
}*p;//p=0x00000000 下面的结果是
int main() {
printf("%p\n", p + 0x1);
printf("%p\n", (unsigned long)p + 0x1);
printf("%p\n", (unsigned int*)p + 0x1);
return 0;
}
答案+图解
struct Test
{
int Num;
char* pcName;
short sDate;
char cha[2];
short sBa[4];
}*p;//*代表这是个结构体指针
//p=0x00000000,下面的结果是
int main() {
printf("%p\n", p + 0x1);//0x00000014
printf("%p\n" ,p + 1);//和上面的等价
⭐//这里是->地址+1
//0x1相当于二进制的1,也就是p(数据类型20个字节)的地址+1;
//跳过一个结构体大小20个字节=0x0000014 /这个1是16(十六进制满16进1),4是4,16+4=20
printf("%p\n", (unsigned long)p + 0x1);//0x00000001
⭐// 这里是->整型+1
// 强转为长整型;转化成整型之后+1,加的就是1 ==0x00000001【例如10+1就是11】
printf("%p\n", (unsigned int*)p + 0x1);//0x00000004
//整型指针跳过4个字节
return 0;
}
图解
⭐笔试题3
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;
}
答案+图解
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);//4(0x00000004), 2000000 (0x02000000)
return 0;
}
图解1
图解2
笔试题4
int main() {
int a[3][2] = { (0,1),(2,3),(4,5) };
int* p;
p = a[0];
printf("%d", p[0]);
return 0;
}
答案+图解
int main() {
int a[3][2] = { (0,1),(2,3),(4,5) };//逗号表达式等价={{1,3},{5,0},{0,0}}
int* p;
p = a[0];//都知道p=1的地址(上节有)
printf("%d", p[0]);//1 p[0]相当于*(p+0)
return 0;
}
图解
简单没图(不是所有牛奶都叫牛奶,不是所有图解都有图)
⭐笔试题5
int main() {
int a[5][5];
int(*p)[4];
p = a;
printf("%p,%d\n",&p[4][2],&a[4][2]);
return 0;
}
答案+图解
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]);//FFFFFFFC,-4
return 0;
}
图解
⭐笔试题6
int main() {
int a[2][5] = { 1,2,3,4,5,6,7,8,9,10 };
int* ptr1 = (int*)(&a+1);
int* ptr2 = (int*)(*(a+1));
printf("%d,%d", *(ptr1 - 1), *ptr2 - 1);
return 0;
}
答案+图解
int main() {
int a[2][5] = { 1,2,3,4,5,6,7,8,9,10 };
int* ptr1 = (int*)(&a+1);
int* ptr2 = (int*)(*(a+1));
printf("%d,%d", *(ptr1 - 1), *(ptr2 - 1));//10,5
return 0;
}
图解
笔试题7
int main() {
char* a[] = { "work","at","alibaba" };
char** pa = a;
pa++;
printf("%s", *pa);
return 0;
}
答案+图解
int main() {
char* a[] = { "work","at","alibaba" };
char** pa = a;
pa++;
printf("%s", *pa);//at
return 0;
}
图解
⭐笔试题8
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;
}
答案+题解
int main() {
char* c[] = { "ENTER","NEW","POINT","FIRST" };
char** cp[] = { c + 3,c + 2,c + 1,c };
char*** cpp = cp;
printf("%s\n", **++cpp);//POINT
printf("%s\n", *-- * ++cpp + 3);//ER
printf("%s\n", *cpp[-2] + 3);//ST
printf("%s\n", cpp[-1][-1] + 1);//EW
return 0;
}
图解