JAVA面试题整理---自我记录

版权声明:本文为博主原创文章,未经博主允许不得转载。http://blog.csdn.net/flower_vip https://blog.csdn.net/flower_vip/article/details/77646089

JAVA基础篇

1.java中的基本数据类型是那些?各自占用多少字节?

答:整数型--byte(8)、short(16)、int(32)、long(64)

               浮点型;float(32)、double(64) 

       布尔型:boolean 

2.String类能被继承嘛?为什么

答:不能,因为stirng类被关键字final修饰,

使用final修饰的原因有两种:1.锁定方法防止任何继承类修改它的意义和实现  2.高效(但新版本持怀疑态度)

3.ArrayList和linkedList有什么区别?

Arraylist是基于动态数组的数据结构

linkedlist是基于双向链表的数据结构。  

对于随机访问get和set方法Arraylist要优于LindedList,因为lindedlist要移动指针,而对于添加和删除数据,如果数据量比较少,且操作的数据相对靠前或靠后,那么Linkedlist

比arraylist效率高,相反如果数据量很大,且操作的数据相对为数据中间部位,那么Arraylist比LinkedList效率好,因为这种情况LinkedList可能要遍历前一半或后一半的数据。

4.类的实例化顺序,比如父类静态数据和构造函数、字段、子类静态数据、构造函数当new时执行顺序

答:遵循先父后子,先静态后非静态,先字段后构造函数

5.用过那些MAP,HashMap是线程安全的嘛?并发下使用那个map,他们内部原理是什么?比如存储方式、hashcode,扩容、默认容量等

6.JAVA8的Concurrenthashmap为什么放弃了分段锁,有什么问题,如果你来设计你如何设计?

7.有没有顺序的map实现类,如果有,他们如何保证有序的

8.抽象类和接口的区别

9.继承和聚合的区别

答:is-a  为继承   has-a 为聚合  is-like-a 为组合、如果 A IS-A B 那么B是A的基类   A has-a B  那么A类中存在B。 A is-like-a B  A和B为组合关系

猜你喜欢

转载自blog.csdn.net/flower_vip/article/details/77646089