从java面试题了解你所模糊的数组
2019-06-19 15:56
1561 查看
前言
数组,最基础的一种数据结构。尽管看起来非常的简单、基础,但是面试往往逃不过它。
特性
- 下标从0开始
- 线性表数据结构
- 一组连续的内存空间来存储一组具有相同类型的数据
如何实现随机访问
从上面的特性可以得到几个关键词:
1.线性表。线性表就是数据排成一条线一样的结构。只有前后两个关系。比如:数组、链表、栈、队列等;
2.连续的内存空间和相同类型的数据。所以你所回答的不适合insert、delete就是基于这个原因,为了保持它的连续性。
数组根据下标实现随机访问数组元素的公式:
a_address = base_address + i * data_type_size
其中,base_address为数组内存块的首地址,data_type_size 为元素大小(比如,数据类型为int,则data_type_size 为4)
如何动态扩容
数组本身在定义的时候就是需要预先指定大小的,因为需要分配连续的内存空间。
以ArrayList来说,每次存储空间不足的时,它都会将空间自动扩容1.5倍。
但是扩容操作涉及到内存申请和数据迁移,比较耗时,所以事先指定好大小是可以优化性能的。
ArrayList给定的默认容量大小是10:
/** * Default initial capacity. */ private static final int DEFAULT_CAPACITY = 10;
扩容源码:
/** * Increases the capacity to ensure that it can hold at least the * number of elements specified by the minimum capacity argument. * * @param minCapacity the desired minimum capacity */ private void grow(int minCapacity) { // overflow-conscious code int oldCapacity = elementData.length; int newCapacity = oldCapacity + (oldCapacity >> 1); if (newCapacity - minCapacity < 0) newCapacity = minCapacity; if (newCapacity - MAX_ARRAY_SIZE > 0) newCapacity = hugeCapacity(minCapacity); // minCapacity is usually close to size, so this is a win: elementData = Arrays.copyOf(elementData, newCapacity); }
最后
想着还是来一波面试题吧
代码如下:
public static void main(String[] args) { int a=10; int b=20; System.out.println("a="+a+" b="+b); change(a, b); System.out.println("a="+a+" b="+b); } public static void change(int a,int b) { a=b; b=a+b; System.out.println("a="+a+" b="+b); }
输出结果:
a=10 b=20 a=20 b=40 a=10 b=20
如果改成数组呢,结果是否有变?
public static void main(String[] args) { int[] arr = {9,3,4,5,6}; change(arr); System.out.println(arr[1]); } public static void change(int[] arr) { for(int i=0;i<arr.length;i++) { if(arr[i] % 3 == 0) { arr[i]*=2; } } }
输出结果:
6
是不是似曾相识,在某场笔试中?记得之前在某公司面试的时候,就出现了这样的题,虽说让我给蒙中了,但是面试官貌似对我很有兴趣(PS:手动狗头),一问到底,为!什!么!你的答案是这样的,来,说说你的思路Or理解。
当时很想说出我的心里话:我蒙的,你信吗?
简单吹了一波:
- 基本数据类型的值传递,不改变原始值,因为方法调用后就会弹栈,局部变量随之消失。
- 引用数据类型的值传递,改变原始值,因为即使方法弹栈,但是堆内存数组对象还在,可以通过地址继续访问。
所以你知道java中到底是传递值还是传递地址呢?
你可以大声告诉你的面试官:值。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
[i]相关文章推荐
- 剑指offer1面试题52 构建乘积数组(java实现)
- 剑指offer-chapter2-面试题8-旋转数组的最小数字(java)
- 剑指Offer:面试题14——调整数组顺序使奇数位于偶数前面(java实现)
- java面试题十 java数组初始化
- 剑指Offer面试题51(Java版):数组中反复的数字
- 剑指Offer面试题36(Java版):数组中的逆序对
- 剑指Offer面试题29(java版):数组中出现次数超过一半的数字
- java面试题---数组中只出现一次的数字
- java笔试面试题--int数组的默认值
- 剑指offer--面试题8:旋转数组的最小数字--Java实现
- 面试题8:找到旋转数组的最小值(java)
- 剑指Offer:面试题8——旋转数组的最小值(java实现)
- java学习第四天 数组来了 但是老师给的题有点简单。在清华光头学长的帮助下,了解了一下自己不太了解的知识
- 《Java 编程技巧1001条》 第389条: 了解不平衡数组
- 从头认识java-14.2 进一步了解数组
- Java数组中常见的面试题
- 全面了解java byte数组与文件读写
- Java面试题多思路解析--有一个已经排好序的数组。现输入一个数,要求按原来的规律将它插入数组中
- 从头认识java-14.2 进一步了解数组
- Java中的数组数据结构需要了解的要点