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的变化。

  • 相关阅读:
    【算法】数据结构
    【POJ】1222 EXTENDED LIGHTS OUT
    【BZOJ】1013 [JSOI2008]球形空间产生器sphere
    【有上下界网络流】【ZOJ】2314 Reactor Cooling
    【CODEVS】1281 Xn数列
    【POJ】3070 Fibonacci
    【CODEVS】3546 矩阵链乘法
    【BZOJ】1070: [SCOI2007]修车
    Quoit Design(hdu 1007)
    tree(poj 1741)
  • 原文地址:https://www.cnblogs.com/miluroe/p/10886854.html
Copyright © 2011-2022 走看看