知识特点(学习方向)
上一篇介绍了更深一步的指针,这一篇将涉及指针运算笔试题解析等一些知识点,每篇内容不多很好理解,相信大家看完这几篇之后会对指针的理解有质的飞跃。
每一个知识点都讲的很细节,已经学明白并掌握第一节指针基础知识点合集1.2.3.4.5. 6.1(侧边有合集栏)的同学让我们一起继续深一步的学习。
多运用类比,希望大家能和前面知识点联系起来,多比较,多研究,祝大家学习愉快。
1.题⽬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;
}
//程序的结果是什么?
运行结果:
1.&a表示整个数组的地址,+1之后跳过了整个数组,强制转化为了int*类型赋给了*ptr
2.*(a+1)中单独一个a说明是第一个元素的地址,+1第二个元素,再解引用(前面合集讲过)所以输出2;
3.ptr本身是整个数组后面的一个地址,-1就表示整个数组的最后一个元素,因此输出的元素是5;
2.题⽬2
//
// //在X86环境下
//假设结构体的⼤⼩是20个字节
//程序输出的结果是啥?
#include<stdio.h>
struct Test
{
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;
}
运行结果:
解析:
1.结构体指针+1,跳过一个结构体就是跳过了一个结构体;
2.已经强制转化为整形,那+1就是+1;
3.强制转化为指针类型,那是地址就是占4个字节;
3.题⽬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;
}
运行结果:
解析:
1.*p是一个整形指针;
2.逗号表达式只取最后一个,因此实际上存入的只有1,3,5;
3.因此第一行第一个就是1,所以输出的就是1;
完—
6.3会再继续分享3道题;
这篇的分享就先到这里,每篇涉及的知识点不是很多但都十分详细,希望对大家有所帮助,有什么问题或者指教都可以提出来哈,记得点赞关注哦!