大佬教程收集整理的这篇文章主要介绍了《C语言》—— 数组详解,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
书籍使我变成了一个幸福的人,使我的生活变成轻松而舒适的诗。——高尔基
本文已经收录至我的GitHub,欢迎大家踊跃star 和 issues。
我本来准备C语言章节就写个指针就ok了,在我看来C语言的精华部分就是指针了。但是有很多同学就开始在群里各种拉扯C语言的其他问题,没办法,我是龙叔嘛,想想还是整理一下,把一些重要的C语言知识点都一一更新了吧。C语言指针的内容请点击 指针(上) 和 指针(下),记得点关注,不迷路
我们把一组数据的集合称为数组(Array),它所包含的每一个数据叫做数组元素(Element),所包含的数据的个数称为数组长度(Length),数组中的每个元素都有一个序号,这个序号从0开始,而不是从我们熟悉的1开始,称为下标(Index),所包含数组的里面元素的类型叫做数组类型(Type)。
一句话就说清楚了数组的基本概念,就是这么简单,^_^。
1int array[5];
内存布局图
不要看这个图简单,底层就是这样的。数组是一个整体,它的内存是连续的;也就是说,数组元素之间是相互挨着的,彼此之间没有一点点缝隙。
这一点很重要,连续的内存为指针操作(通过指针来访问数组元素)和内存处理(整块内存的复制、写入等)提供了便利,这使得数组可以作为缓存使用。
有同学估计要说什么叫做指针操作,听龙叔絮叨下。
int arr[5] = {1,2,1); word-wrap: inherit !important; word-break: inherit !important">3,1); word-wrap: inherit !important; word-break: inherit !important">4,1); word-wrap: inherit !important; word-break: inherit !important">5};
2printf("%d\n",arr[3]);
看上面的代码,学过数组都知道arr[3]是取第三个元素的值,那我就要问你了,怎么取到值的呢???
不要慌,龙叔告诉你其实就是指针操作。当我们声明并定义数组int arr[5] = {1,2,3,4,5}
,此时数组被分配了5个int大小的空间在栈上,并初始化了数组元素。我们都知道数组名代表数组的首元素的首地址,那么很明显就可以得到arr[3] = arr + 3
。指针的加减操作详情请看龙叔公号,微信搜索 龙跃十二 即可订阅喔。
1int a[] = {4};
2sizeof(a));
3sizeof(a+0));
4sizeof(*a));
51));
6sizeof(a[1]));
7sizeof(&a));
8sizeof(&a+ 9sizeof(&a[0]));
100]+11//字符数组
12char arr[] = {'a','b',1); word-wrap: inherit !important; word-break: inherit !important">'c',1); word-wrap: inherit !important; word-break: inherit !important">'d',1); word-wrap: inherit !important; word-break: inherit !important">'e',1); word-wrap: inherit !important; word-break: inherit !important">'f'};
13sizeof(arr));
14sizeof(arr+15sizeof(*arr));
16sizeof(arr[17sizeof(&arr));
18sizeof(&arr+19sizeof(&arr[20strlen(arr));
21strlen(arr+22strlen(*arr));
23strlen(arr[24strlen(&arr));
25strlen(&arr+26strlen(&arr[27char *p = "abcdef";sizeof(p));
28sizeof(p+29sizeof(*p));
30sizeof(p[31sizeof(&p));
32sizeof(&p+33sizeof(&p[34strlen(p));
35strlen(p+36strlen(*p));
37strlen(p[38strlen(&p));
39strlen(&p+40strlen(&p[41//二维数组
42int a[3][4] = {0};
43440][4546474849503]));
就这几个运算,估计会难倒很多同学的,不信你可以把答案写出来之后在去跑一遍,全对找我拿红包。
sizeof(数组名),代表整个数组的字节数;&数组名,代表取得整个数组的地址。
数组底层内存结构是连续的。正是由于数组结构的连续性便诞生了内存的友好性,数组分配内存是整块分配的,堆内存很友好;连续的内存是的访问内存效率高。
int b;
scanf("%d",&b);
33*b];
不知道你曾经有没有写过这样的代码,反正我写过。数组的长度和内存是在程序编译时就已经确定了的。b的值是在运行时才确定的。有两个新名词,程序编译时&程序运行时。
-1]);
31]);
44]);
55]);
66]);
肉眼可见的错误,编译器竟然没报错。
利用数组可以出很多笔试题目,当然这些题目很多并不是考验数组本身特性大多是考算法基础的。本节就到这里了,有什么不清楚的问题欢迎留言喔,也可私信或mail。
往期精彩回顾:
以上是大佬教程为你收集整理的《C语言》—— 数组详解全部内容,希望文章能够帮你解决《C语言》—— 数组详解所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。