核心
- 什么是指针 : 用来存放地址
- 一级指针和二级指针,三级…指针 : 三级指针指向的是二级指针,二级指针指向的是一级指针
- 相同地方 : 存放的都是地址
- 不同 : 指针所代表的大小(加 1 的跨度)取决于指针所指向的数据的类型
- 指针数组 : 数组, 存放指针
- 数组指针 : 指针, 指向一个数组
- 数组和指针的区别和联系 : 没联系
题目
int main() {
int a[5] = { 1, 2, 3, 4, 5 };
int *ptr = (int *)(&a + 1);// &数组名 代表整个数组的地址,加 1 跨过整个数组
printf("%d,%d", *(a + 1), *(ptr - 1));// ptr 的指向的数据为int ,减去 1,指向数组的最后一个元素
return 0;
}
struct Test {
int Num;
char *pcName;
short sDate;
char cha[2];
short sBa[4];
}*p; //假设p 的值为0x100000。结构体大小为 20 个字节
int main() {
printf("%p\n", p + 0x1);//p 指向结构体,加 1,就等于加上 20 个字节
printf("%p\n", (unsigned long)p + 0x1); //强转为整型
printf("%p\n", (unsigned int*)p + 0x1);//强转为整型指针
return 0;
}
int main(){
int a[4] = { 1, 2, 3, 4 };
int *ptr1 = (int *)(&a + 1);//&a 代表整个数组的地址,加 1,跨过整个数组,在强转为指向int 的指针
int *ptr2 = (int *)((int)a + 1);//先把指针强转为整型,加 1,再转成指向int 的指针
printf("%x,%x", ptr1[-1], *ptr2);//
return 0;
}
int main() {
int a[3][2] = { (0, 1), (2, 3), (4, 5) };//大括号里是逗号表达式
int *p;
p = a[0];
printf("%d", p[0]);
}
int main() {
int a[5][5];
int(*p)[4];//指针数组,是一个指针,指向的数组中有 4 个元素
p = a;//a 的类型是 int(*)[5]
printf("%p,%d\n", &p[4][2] - &a[4][2], &p[4][2] - &a[4][2]);
return 0;
}
int main() {
int aa[2][5] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
int *ptr1 = (int *)(&aa + 1);//&aa 代表整个数组的地址,加 1,跨过整个数组,强转为指向int 的指针
int *ptr2 = (int *)(*(aa + 1));//相当于 (int *)aa[1],第二行元素为数组,数组名隐式转换为指针,强转为指向int 的指针
printf("%d,%d", *(ptr1 - 1), *(ptr2 - 1));
return 0;
}
int main() {
char *a[] = { "work", "at", "alibaba" };
char**pa = a;
pa++;
printf("%s\n", *pa);
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);
printf("%s\n", *--*++cpp + 3);
printf("%s\n", *cpp[-2] + 3);
printf("%s\n", cpp[-1][-1] + 1);
return 0;
}