美文网首页
2019JAVA面试题附答案

2019JAVA面试题附答案

作者: 崖敌_39ad | 来源:发表于2019-04-11 10:02 被阅读0次

    JAVA基础

    JAVA中的几种基本类型,各占用多少字节?

    String能被继承吗?为什么?

    不可以,因为String类有final修饰符,而final不能被继承的,实现细节不允许改变。平常我们定义的String str = " a ";其实和String str = new String("a");还是有差异的。

    前者默认调用的String.valueof来返回String的实例对象,至于调用哪个则取决于你的赋值,比如String num = 1;调用的是public static String valueOf(int i){

       return Integer.toString(i);

    }

    后者则是调用如下部分:

    public String(String original) {

    this.value = original.value;

    this.hash = original.hash;

    }

    最后我们的变量都存储在一个char数组中。

    private final char value[];

    String, Stringbuffer, StringBuilder 的区别。

    String 字符串常量(final修饰,不可被继承),String是常量,当创建之后即不能更改。(可以通过StringBuffer和StringBuilder创建String对象(常用的两个字符串操作类)。) 

    StringBuffer 字符串变量(线程安全),其也是final类别的,不允许被继承,其中的绝大多数方法都进行了同步处理,包括常用的Append方法也做了同步处理。其自jdk1.0起就已经出现。其toString方法会进行对象缓存,以减少元素的复制开销。

    public synchronized String toString() {

    if (toStringCache == null) {

    toStringCache = Arrays.copyOfRange(value, 0, count);

    }

    return new String(toStringCache, true);

    }

    StringBuilder 字符串变量,(非线程安全)其自jdk1.5起开始出现。与StringBuffer一样都继承和实现同一个接口和类,方法除了没有使用synch修饰以外基本一致,不同之处在于最后toString的时候,会直接返回一个新对象。

    public String toString() {

    // Create a copy, don’t share the array

    return new String(value, 0, count);

    }

    ArrayList 和 LinkedList 有什么区别。

    ArrayList和LinkedList都实现了List接口,有以下的不同点: 

    1.ArrayList是基于索引的数据接口。它的底层是数组。它可以以O(1)时间复杂度对元素进行随机访问。以此对应,LinkedList是以元素列表的形式存储的数据,每一个元素都和它的前一个后一个元素链接在一起,在这种情况下,查找某个元素的时间复杂度是O(n)。 

    2.相对于ArrayList,LinkedList的插入,添加,删除操作速度更快,因为当元素被添加到集合任意位置的时候,不需要像数组那样重新计算大小或者是更新索引。

    3.LinkedList比ArrayList更占内存,因为LinkedList为每一个节点存储了两个引用,一个指向前一个元素,一个指向下一个元素。

    讲讲类的实例化顺序,比如父类静态数据,构造函数,字段,子类静态数据,构造函数,字段,当 new 的时候, 他们的执行顺序。

    父类静态代变量、

    父类静态代码块、

    子类静态变量、

    子类静态代码块、

    父类非静态变量(父类实例成员变量)、

    父类构造函数、

    子类非静态变量(子类实例成员变量)、

    子类构造函数。

    用过哪些 Map 类,都有什么区别,HashMap 是线程安全的吗,并发下使用的 Map 是什么,他们内部原理分别是什么,比如存储方式, hashcode,扩容, 默认容量等。

    hashMap是线程不安全的,HashMap是数组+链表+红黑树(JDK1.8增加了红黑树部分)实现的,采用哈希表来存储的,

    参照该链接:https://zhuanlan.zhihu.com/p/21673805

    JAVA8 的 ConcurrentHashMap 为什么放弃了分段锁,有什么问题吗,如果你来设计,你如何设计。

    参照:https://yq.aliyun.com/articles/36781

    有没有顺序的Map实现类,如果有,他们是怎么保证有序的。

    TreeMap和LinkedHashMap是有序的(TreeMap默认升序,LinkedHashMap则记录了插入顺序)。

    参照:http://uule.iteye.com/blog/1522291

    抽象类和接口的区别,类可以继承多个类么,接口可以继承多个接口么,类可以实现多个接口么。

    1、抽象类和接口都不能直接实例化,如果要实例化,抽象类变量必须指向实现所有抽象方法的子类对象,接口变量必须指向实现所有接口方法的类对象。 

    2、抽象类要被子类继承,接口要被类实现。

    3、接口只能做方法申明,抽象类中可以做方法申明,也可以做方法实现 

    4、接口里定义的变量只能是公共的静态的常量,抽象类中的变量是普通变量。 

    5、抽象类里的抽象方法必须全部被子类所实现,如果子类不能全部实现父类抽象方法,那么该子类只能是抽象类。同样,一个实现接口的时候,如不能全部实现接口方法,那么该        类也只能为抽象类。 

    6、抽象方法只能申明,不能实现。abstract void abc();不能写成abstract void abc(){}。 

    7、抽象类里可以没有抽象方法 。

    8、如果一个类里有抽象方法,那么这个类只能是抽象类 。

    9、抽象方法要被实现,所以不能是静态的,也不能是私有的。 

    10、接口可继承接口,并可多继承接口,但类只能单根继承。

    继承和聚合的区别在哪。

    继承指的是一个类(称为子类、子类接口)继承另外一个类(称为父类、父接口)的功能,并可以增加它自己的新功能,继承是类与类或者接口之间最常见的关系。在java中此类关系通过关键字exetents明确标识,在设计时候一般没有争议性。

    相关文章

      网友评论

          本文标题:2019JAVA面试题附答案

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