zoukankan      html  css  js  c++  java
  • Java面试细节整理(不断更新)

    1. 内存模型

    1.1 对象缓存

    public static void main(String[] args) {
        Integer a = 127, b = 127, c = -128, d = -128;
        Integer e = 128, f = 128, g = -129, h = -129;
        System.out.println(a == b); // true
        System.out.println(c == d); // true
        System.out.println(e == f); // false
        System.out.println(g == h); // false
    }

      JVM对基本类型(boolean, float, double除外)进行了缓存,Integer默认范围是-128~127并可通过JVM参数修改上限,由于Integer是final类,故缓存范围内的Integer自动装箱时不产生新对象。

    2. 集合框架

    2.1 方法 List<E> subList(int fromIndex, int toIndex)

    public static void main(String[] args) {
        List<Integer> arrayList = new ArrayList<Integer>(10);
        List<Integer> linkedList = new LinkedList<Integer>();
        for (int i = 0; i < 10; i++) {
            arrayList.add(i);
            linkedList.add(i);
        }
        List<Integer> subArrayList = arrayList.subList(1, 4);
        List<Integer> subLinkedList = arrayList.subList(1, 4);
        System.out.println(subArrayList.getClass()); // class java.util.ArrayList$SubList
        System.out.println(subLinkedList.getClass()); // class java.util.ArrayList$SubList
        arrayList = (ArrayList<Integer>) subArrayList; // throws java.lang.ClassCastException
    }

      List接口声明了subList方法,ArrayList与LinkedList中subList返回ArrayList中非静态内部内SubList作为原List的视图,对SubList的修改会造成原List的变化。

  • 相关阅读:
    使用ConcurrentHashMap需要知道的细节
    并查集(Union-Find)
    LeetCode2
    补充之前博客的几种排序--希尔排序、堆排序、归并排序
    左式二叉堆
    优先队列的一种实现--堆ADT
    开放地址法散列表ADT
    分离链表法散列ADT
    AVL树
    二叉查找树ADT--C语言描述
  • 原文地址:https://www.cnblogs.com/miluroe/p/10886854.html
Copyright © 2011-2022 走看看