美文网首页Java 杂谈
java面试:你所逃脱不了的数组

java面试:你所逃脱不了的数组

作者: 话尔loony | 来源:发表于2019-06-12 18:28 被阅读1次

数组,最基础的一种数据结构。尽管看起来非常的简单、基础,但是面试往往逃不过它。

特性
  • 下标从0开始
  • 线性表数据结构
  • 一组连续的内存空间来存储一组具有相同类型的数据
如何实现随机访问

从上面的特性可以得到几个关键词:

  1. 线性表。线性表就是数据排成一条线一样的结构。只有前后两个关系。比如:数组、链表、栈、队列等;
  2. 连续的内存空间和相同类型的数据。所以你所回答的不适合insert、delete就是基于这个原因,为了保持它的连续性。
    数组根据下标实现随机访问数组元素的公式:
    a[i]_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中到底是传递值还是传递地址呢?

你可以大声告诉你的面试官:值。(PS:支持者:高司令)

相关文章

  • java面试:你所逃脱不了的数组

    数组,最基础的一种数据结构。尽管看起来非常的简单、基础,但是面试往往逃不过它。 特性 下标从0开始 线性表数据结构...

  • Java基础面试知识点

    Java基础面试知识点 一.容器(HashMap、HashSet、LinkedList、ArrayList、数组等...

  • java面试数组相关

    笔试题目一: 问如下代码能否编译通过?并说明相应的理由。 答案:可以编译通过,首先要知道一个事实数组存储的不是对象...

  • 培训的本质

    前几天去参加培训主管的面试,面试的问题中永远逃脱不了培训效果的评估这个话题。 培训效果评估当然重要,也是难点之一,...

  • Java数组总结

    前言 开发中避免不了和数据打交道,今天给大家介绍Java中的数组 目录 1.数组类型 1.1 理解数组 定义数组是...

  • 程序员面试题——Java中数组的基本概念

    程序员面试题——Java中数组的基本概念 本文将通过四个例题来讲解Java中有关数组的基本知识,供读者学习和复习:...

  • 逃脱不了你的魔掌

    是谁把记忆 抹成了忧伤的模样 是谁把思念 串成了是秋的悲凉 是谁把温柔的你 塞进了我颓靡的心房 又是谁让...

  • 命运只是无能为力的妥协

    我所理解的命运就是, 你逃脱不了你无能为力的事, 因为这件事, 与你的性格弱点有些极大的关联, 而这些弱点, 不是...

  • 逃脱不了

    手脚冰凉,头疼欲裂,腰酸背疼,嗓子发痒,这是阳的节奏么? 昨天还得意自己是天选打工人,看来是天选打脸人。 儿子说,...

  • 在Java路上,我看过的一些书、源码和框架

    物有本末,事有终始,知所先后,则近道矣 面试经历 关于Java面试,你应该准备这些知识点http://www.ji...

网友评论

    本文标题:java面试:你所逃脱不了的数组

    本文链接:https://www.haomeiwen.com/subject/yrrrfctx.html