更新时间:2020-06-10 15:26:43 来源:极悦 浏览1827次
1、JAVA中的几种基本数据类型是什么,各自占用多少字节。
2、String类能被继承吗,为什么
不能。在Java中,只要是被定义为final的类,也可以说是被final修饰的类,就是不能被继承的。
3、String,Stringbuffer,StringBuilder的区别。
4、ArrayList和LinkedList有什么区别。
简单的区别:
(1)ArrayList是实现了基于动态数组的数据结构,LinkedList基于链表的数据结构。(LinkedList是双向链表,有next也有previous)
(2)对于随机访问get和set,ArrayList觉得优于LinkedList,因为LinkedList要移动指针。
(3)对于新增和删除操作add和remove,LinedList比较占优势,因为ArrayList要移动数据。
深度的区别:
(1)对ArrayList和LinkedList而言,在列表末尾增加一个元素所花的开销都是固定的。对ArrayList而言,主要是在内部数组中增加一项,指向所添加的元素,偶尔可能会导致对数组重新进行分配;而对LinkedList而言,这个开销是统一的,分配一个内部Entry对象。
(2)在ArrayList的中间插入或删除一个元素意味着这个列表中剩余的元素都会被移动;而在LinkedList的中间插入或删除一个元素的开销是固定的。
(3)LinkedList不支持高效的随机元素访问。
(4)ArrayList的空间浪费主要体现在在list列表的结尾预留一定的容量空间,而LinkedList的空间花费则体现在它的每一个元素都需要消耗相当的空间
5、讲讲类的实例化顺序。
问题:比如父类静态数据,构造函数,字段,子类静态数据,构造函数,字段,当new的时候,他们的执行顺序。
答案:类加载器实例化时进行的操作步骤(加载–>连接->初始化)。父类静态变量、父类静态代码块、子类静态变量、子类静态代码块、父类非静态变量(父类实例成员变量)、父类构造函数、子类非静态变量(子类实例成员变量)、子类构造函数。
6、用过哪些Map类,都有什么区别。
问题:比如HashMap是线程安全的吗,并发下使用的Map是什么,他们内部原理分别是什么,比如存储方式,hashcode,扩容,默认容量等。答案:不安全,并发下使用ConcurrentHashMap。
7、JAVA8的ConcurrentHashMap为什么放弃了分段锁?
原因:通过JDK的源码和官方文档看来,他们认为的弃用分段锁的原因由以下几点:1、加入多个分段锁浪费内存空间。2、生产环境中,map在放入时竞争同一个锁的概率非常小,分段锁反而会造成更新等操作的长时间等待。3、为了提高GC的效率
既然弃用了分段锁,那么一定由新的线程安全方案,我们来看看源码是怎么解决线程安全的呢?CAS
首先通过hash找到对应链表过后,查看是否是第一个object,如果是,直接用cas原则插入,无需加锁,然后如果不是链表第一个object,则直接用链表第一个object加锁,这里加的锁是synchronized,虽然效率不如ReentrantLock,但节约了空间,这里会一直用第一个object为锁,直到重新计算map大小,比如扩容或者操作了第一个object为止。
8、ConcurrentHashMap(JDK1.8)为什么要使用synchronized而不是如ReentranLock这样的可重入锁?
可以从下面几个方面讲述:锁的粒度首先锁的粒度并没有变粗,甚至变得更细了。每当扩容一次,ConcurrentHashMap的并发度就扩大一倍。Hash冲突JDK1.7中,ConcurrentHashMap从过二次hash的方式(Segment->HashEntry)能够快速的找到查找的元素。在1.8中通过链表加红黑树的形式弥补了put、get时的性能差距。扩容JDK1.8中,在ConcurrentHashmap进行扩容时,其他线程可以通过检测数组中的节点决定是否对这条链表(红黑树)进行扩容,减小了扩容的粒度,提高了扩容的效率。
为什么是synchronized,而不是可重入锁
减少内存开销假设使用可重入锁来获得同步支持,那么每个节点都需要通过继承AQS来获得同步支持。但并不是每个节点都需要获得同步支持的,只有链表的头节点(红黑树的根节点)需要同步,这无疑带来了巨大内存浪费。
获得JVM的支持可重入锁毕竟是API这个级别的,后续的性能优化空间很小。synchronized则是JVM直接支持的,JVM能够在运行时作出相应的优化措施:锁粗化、锁消除、锁自旋等等。这就使得synchronized能够随着JDK版本的升级而不改动代码的前提下获得性能上的提升。
9、有没有有顺序的Map实现类,如果有,他们是怎么保证有序的。
Hashmap和Hashtable都不是有序的。TreeMap和LinkedHashmap都是有序的。(TreeMap默认是key升序,LinkedHashmap默认是数据插入顺序)TreeMap是基于比较器Comparator来实现有序的。LinkedHashmap是基于链表来实现数据插入有序的。
10、抽象类和接口的区别,类可以继承多个类么,接口可以继承多个接口么,类可以实现多个接口么。
区别:1、抽象类和接口都不能直接实例化,如果要实例化,抽象类变量必须指向实现所有抽象方法的子类对象,接口变量必须指向实现所有接口方法的类对象。2、抽象类要被子类继承,接口要被类实现。3、接口只能做方法申明,抽象类中可以做方法申明,也可以做方法实现4、接口里定义的变量只能是公共的静态的常量,抽象类中的变量是普通变量。5、抽象类里的抽象方法必须全部被子类所实现,如果子类不能全部实现父类抽象方法,那么该子类只能是抽象类。同样,一个实现接口的时候,如不能全部实现接口方法,那么该类也只能为抽象类。6、抽象方法只能申明,不能实现。abstract void abc();不能写成abstract void abc(){}。7、抽象类里可以没有抽象方法8、如果一个类里有抽象方法,那么这个类只能是抽象类9、抽象方法要被实现,所以不能是静态的,也不能是私有的。10、接口可继承接口,并可多继承接口,但类只能单根继承。
类不能继承多个类接口可以继承多个接口类可以实现多个接口
以上就是极悦java培训机构的小编针对“Java基础部分组成27个知识点”的内容进行的回答,希望对大家有所帮助,如有疑问,请在线咨询,有专业老师随时为你服务。
0基础 0学费 15天面授
Java就业班有基础 直达就业
业余时间 高薪转行
Java在职加薪班工作1~3年,加薪神器
工作3~5年,晋升架构
提交申请后,顾问老师会电话与您沟通安排学习