博客
关于我
Java面试之数组(详细)
阅读量:174 次
发布时间:2019-02-28

本文共 1277 字,大约阅读时间需要 4 分钟。

1、什么是数组?

数组(Array)是一种线性表数据结构,它用一组连续的内存空间,来存储相同类型的数据。

 

2 、什么是线性表(Linear List)?

线性表就是数据排成一条线一样的结构,每个线性表的数据最多只有前后两个方向。

例如:数组,链表,队列,栈 等都是线性表结构。

 

3、 什么是非线性表?

例如:二叉树,堆,图,等,是非线性表,是因为,在非线性表中,数据之间并不是简单的前后关系。

 

4、 数组是如何随机访问数组元素?

数组是如何实现根据下标随机访问数组元素的吗?

例如: int[]a=newint[10]

1,计算机给数组a[10],分配了一组连续的内存空间。2,比如内存块的首地址为 base_address=1000。3,当计算给每个内存单元分配一个地址,计算机通过地址来访问数据。当计算机需要访问数组的某个元素的时候,会通过一个寻址公式来计算存储的内存地址。

公式如下:

a[i]_address = base_address + i * data_type_size

arr[i] 首地址 = 数组内存块首地址 + 数据类型大小 * i ,其中i为偏移量。

baseaddress:内存块的首地址。datatype_size:数组中每个元素的大小,比如每个元素大小是4个字节。

1,数组使用二分法查找元素,时间复杂度是O(logn)。2,根据下标随机访问的时间复杂度是O(1)。

 

5、数组如何提高效率?

将多次删除操作中集中在一起执行,可以先记录已经删除的数据,但是不进行数据迁移,而仅仅是记录,当发现没有更多空间存储时,再执行真正的删除操作,这样减少数据搬移次数节省耗时。

这也是跟 JVM 标记清除垃圾回收算法的核心思想相似。

标记-整理垃圾回收算法。

在垃圾收集时此算法分为“标记”、“清除”两个阶段,先标记出需要回收的对象,再统一清除标记的对象。清除之后会产生大量不连续的内存碎片。

标记-整理垃圾回收算法

在标记完成之后让所有存活的对象都向一端移动,然后直接清理掉边界以外的内存。

 

6、用数组还是容器?

数组先指定容器大小,容器ArrayList可以动态扩容,并且封装了好多方法,一旦超过存储容量,扩容时比较耗时,因为涉及内存申请和数据复制搬移到扩容后的数组。

如果已知数据大小,且涉及的数据操作比较简单,可以用数组。2,比如已知 1 万条数据要存入 ArrayList,我们就可以事先指定容器大小。

例如下代码,就可以,省掉多次的,内存申请,和数据搬移操作

  1. ArrayList<User> users = new ArrayList(10000);
  2. for (int i = 0; i < 10000; ++i) {
  3. users.add(xxx);
  4. }

容器无法存储基本类型,比如 int long 需要转换成包装类型,类型的转换有性能消耗。4,业务开发,使用容器足够,追求性能,首先用数组。

 

7、为什么数组要从 0 开始编号,而不是1?

从偏移角度理解a[0] 0为偏移量,如果从1计数,会多出K-1,增加cpu负担。

 

转载地址:http://zwdi.baihongyu.com/

你可能感兴趣的文章
net发布的dll方法和类显示注释信息(字段说明信息)[图解]
查看>>
Net和T-sql中的日期函数操作
查看>>
Net处理html页面元素工具类(HtmlAgilityPack.dll)的使用
查看>>
Net操作Excel(终极方法NPOI)
查看>>
Net操作配置文件(Web.config|App.config)通用类
查看>>
net网络查看其参数state_dict,data,named_parameters
查看>>
Net连接mysql的公共Helper类MySqlHelper.cs带MySql.Data.dll下载
查看>>
NeurIPS(神经信息处理系统大会)-ChatGPT4o作答
查看>>
neuroph轻量级神经网络框架
查看>>
Neutron系列 : Neutron OVS OpenFlow 流表 和 L2 Population(7)
查看>>
new Blob()实现不同类型的文件下载功能
查看>>
New Concept English three (35)
查看>>
NEW DATE()之参数传递
查看>>
New Journey--工作五年所思所感小记
查看>>
new Queue(REGISTER_DELAY_QUEUE, true, false, false, params)
查看>>
New Relic——手机应用app开发达人的福利立即就到啦!
查看>>
new work
查看>>
new 一个button 然后dispose,最后这个button是null吗???
查看>>
NewspaceGPT的故事续写能力太强了
查看>>
NewspaceGPT绘制时序图
查看>>