int a = 5;
int *b;
b = a;//b的存储空间里放入的是a,不是内存地址,*b意味着b的存储空间的内容(指针)所指向的内存地址的存储空间的内容(卧槽,我都觉得别嘴),所以当b的存储空间内容不是内存地址(指针)时,printf打印*b时会报错bad_access,
printf("a:%d,&a:%d---b:%d,&b:%d,*b:%d\n",a,&a,b,&b,b);
打印结果:a:5,&a:1606416276---b:5,&b:1606416264,*b:5
b = &a;//b的存储空间放的是a的内存地址,所以printf可以打印*b
printf("a:%d,&a:%d---b:%d,&b:%d,*b:%d\n",a,&a,b,&b,*b);
打印结果:a:5,&a:1606416276---b:1606416276,&b:1606416264,*b:5
int *c = b;//直接声明时,*c意味着c的存储空间内容是b存储空间的内容,相当于复制了一遍b,只不过内存地址不一样而已
printf("a:%d,&a:%d---b:%d,&b:%d,*b:%d---c:%d,&c:%d,*c:%d\n",a,&a,b,&b,*b,c,&c,c);
打印结果:a:5,&a:1606416276---b:1606416276,&b:1606416264,*b:5---c:1606416276,&c:1606416256,*c:1606416276
*c = 1;//此时的*c意味着c所指向的内存地址的存储空间内容改变为1,也就是将a变量的值改为1,但是b、c的存储空间和内存地址都没改变,只不过*b、*c的值被改变
printf("a:%d,&a:%d---b:%d,&b:%d,*b:%d---c:%d,&c:%d,*c:%d\n",a,&a,b,&b,*b,c,&c,*c);
打印结果:a:1,&a:1606416276---b:1606416276,&b:1606416264,*b:1---c:1606416276,&c:1606416256,*c:1
a = 4;//a单纯的改变存储空间的内容,所以*b、*c的值都改变,b、c的存储空间内容和内存地址都没改变
printf("a:%d,&a:%d---b:%d,&b:%d,*b:%d---c:%d,&c:%d,*c:%d\n",a,&a,b,&b,*b,c,&c,*c);
打印结果:a:4,&a:1606416276---b:1606416276,&b:1606416264,*b:4---c:1606416276,&c:1606416256,*c:4
b = 3;//b只改变了自己存储空间的内容,原内容是指向a的指针,现改为数字3,所以a、c值都没有发生变化
printf("a:%d,&a:%d---b:%d,&b:%d,*b:%d---c:%d,&c:%d,*c:%d\n",a,&a,b,&b,b,c,&c,*c);
打印结果:a:4,&a:1606416276---b:3,&b:1606416264,*b:3---c:1606416276,&c:1606416256,*c:4
c = 2;//同b=3一致
printf("a:%d,&a:%d---b:%d,&b:%d,*b:%d---c:%d,&c:%d,*c:%d\n",a,&a,b,&b,b,c,&c,c);
打印结果:a:4,&a:1606416276---b:3,&b:1606416264,*b:3---c:2,&c:1606416256,*c:2
b = &a;
int *d = &b;//与c不同,将b的内存地址放入d的存储空间
printf("a:%d,&a:%d---b:%d,&b:%d,*b:%d---d:%d,&d:%d,*d:%d\n",a,&a,b,&b,*b,d,&d,*d);
打印结果:a:4,&a:1606416276---b:1606416276,&b:1606416264,*b:4---d:1606416264,&d:1606416248,*d:1606416276
*d = a;//*d意味着d的存储空间所指向的内存地址的存储空间内容(即b的存储空间内容)改为a的值,所以printf时不能打印*b
printf("a:%d,&a:%d---b:%d,&b:%d,*b:%d---d:%d,&d:%d,*d:%d\n",a,&a,b,&b,b,d,&d,*d);
打印结果:a:4,&a:1606416276---b:4,&b:1606416264,*b:4---d:1606416264,&d:1606416248,*d:4
存储空间和内存地址的关系如图:
图片出处:http://blog.csdn.net/tianmaxingkong_/article/details/41593483 在此表示感谢
//指针++
int a = 5;
int *b;
b = &a;
printf("a:%d,&a:%d,*a:%d---b:%d,&b:%d,*b:%d\n",a,&a,a,b,&b,*b);
//打印结果:a:5,&a:1606416252,*a:5---b:1606416252,&b:1606416240,*b:5
b++;//此时的b++ 意味着b的存储空间内容++,内容为1606416252,int类型占4字节,所以b++后为1606416256,即指向下一个内存地址的内容,而1606416256内存地址的存储空间内容不清楚,所以*b的结果很随机
printf("a:%d,&a:%d,*a:%d---b:%d,&b:%d,*b:%d\n",a,&a,a,b,&b,*b);
//指针与一维数组(二维数组原理一致)
int array[10],*p;
p = array;//此时相当于将二维数组的第一个元素的地址赋予p,相当于 p = &array[0]
for (int i = 0; i < 10; i++) {
*p++ = i;
//此时的*p++不会像 指向int类型时一次跳4个字节,此时会跳到下一个字节,即array下一个元素的内存地址
}
p = array;//将p指针重新指回到array数组的首元素地址
for (int j = 0; j < 10; j++ ) {
printf("array[%d] : %d\n", j, *p++);//依次将指针后移,打印所有数组元素
}
//指针与字符串,与数组原理相同
char str1[] = "you are so beautiful";
char str2[] = "";
char *p1,*p2;
p1 = str1;
p2 = str2;
while (*p1 != '\0') {
*p2 = *p1;
p1++;
p2++;
}
printf("str2[] is :%s\n", str2);
打印结果:str2[] is :you are so beautifull
int类型的指针++内存示意图:
数组类型的指针++内存示意图: