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类型的指针++内存示意图:
数组类型的指针++内存示意图: