C语言第十九弹---指针(三)
(图片来源网络,侵删)
✨个人主页: 熬夜学编程的小林
💗系列专栏: 【C语言详解】 【数据结构详解】
指针
1、数组名的理解
2、使用指针访问数组
(图片来源网络,侵删)
3、⼀维数组传参的本质
4、冒泡排序
5、二级指针
6、指针数组
7、指针数组模拟二维数组
总结
(图片来源网络,侵删)
1、数组名的理解
在上⼀个章节我们在使用指针访问数组的内容时,有这样的代码:int arr[10] = {1,2,3,4,5,6,7,8,9,10}; int *p = &arr[0];这里我们使用 &arr[0] 的方式拿到了数组第⼀个元素的地址,但是其实数组名本来就是地址,而且 是数组首元素的地址,我们来做个测试。
#include int main() { int arr[10] = { 1,2,3,4,5,6,7,8,9,10 }; printf("&arr[0] = %p\n", &arr[0]); printf("arr = %p\n", arr); return 0; }输出结果:
![C语言第十九弹---指针(三)](https://img-blog.csdnimg.cn/direct/2248d0020ad34c33831fdc91caa5bb62.png)
#include int main() { int arr[10] = { 1,2,3,4,5,6,7,8,9,10 }; printf("%d\n", sizeof(arr)); return 0; }
![C语言第十九弹---指针(三)](https://img-blog.csdnimg.cn/direct/a0978ec02f024ba18a4cc9ecc12212f7.png)
#include int main() { int arr[10] = { 1,2,3,4,5,6,7,8,9,10 }; printf("&arr[0] = %p\n", &arr[0]); printf("arr = %p\n", arr); printf("&arr = %p\n", &arr); return 0; }
![C语言第十九弹---指针(三)](https://img-blog.csdnimg.cn/direct/92c9c73c4316465c8099039959def24e.png)
#include int main() { int arr[10] = { 1,2,3,4,5,6,7,8,9,10 }; printf("&arr[0] = %p\n", &arr[0]); printf("&arr[0]+1 = %p\n", &arr[0]+1); printf("arr = %p\n", arr); printf("arr+1 = %p\n", arr+1); printf("&arr = %p\n", &arr); printf("&arr+1 = %p\n", &arr+1); return 0; }输出结果:
&arr[0] = 0136FAA0 &arr[0]+1 = 0136FAA4 arr = 0136FAA0 arr+1 = 0136FAA4 &arr = 0136FAA0 &arr+1 = 0136FAC8这里我们发现&arr[0]和&arr[0]+1相差4个字节,arr和arr+1 相差4个字节,是因为&arr[0] 和 arr 都是首元素的地址,+1就是跳过⼀个元素。 但是&arr 和 &arr+1相差40个字节,这就是因为&arr是数组的地址,+1 操作是跳过整个数组的。 到这里uu们应该搞清楚数组名的意义了吧。 数组名是数组首元素的地址,但是有2个例外。
2、使用指针访问数组
有了前面知识的支持,再结合数组的特点,我们就可以很方便的使用指针访问数组了。#include int main() { int arr[10] = {0}; //输⼊ int i = 0; int sz = sizeof(arr)/sizeof(arr[0]);//数组个数 //输⼊ int* p = arr; for(i=0; i
文章版权声明:除非注明,否则均为主机测评原创文章,转载或复制请以超链接形式并注明出处。
还没有评论,来说两句吧...