当前位置:首页 > Java程序 > 正文内容

java八股文在哪看(java八股文要看多久)

abcsky883个月前 (02-10)Java程序83

本文分享给大家的是:

1. Java 容器都有哪些?Java 容器分为 Collection 和 Map 两大类,其下又有很多子类,如下所示:CollectionListArrayListLinkedListVectorStack

java八股文在哪看(java八股文要看多久)

SetHashSetLinkedHashSetTreeSetMapHashMapLinkedHashMapTreeMapConcurrentHashMapHashtable2. Collection 和 Collections 有什么区别?

Collection 是一个集合接口,它提供了对集合对象进行基本操作的通用接口方法,所有集合都是它的子类,比如 List、Set 等网站名词解释词Collections 是一个包装类,包含了很多静态方法,不能被实例化,就像一个工具类,比如提供的排序方法: Collections. sort(list)。

3. List、Set、Map 之间的区别是什么?List、Set、Map 的区别主要体现在两个方面:元素是否有序、是否允许元素重复。三者之间的区别,如下表:

4. HashMap 和 Hashtable 有什么区别?存储:HashMap 允许 key 和 value 为 null,而 Hashtable 不允许线程安全:Hashtable 是线程安全的,而 HashMap 是非线程安全的。

推荐使用:在 Hashtable 的类注释可以看到网站名词解释词,Hashtable 是保留类不建议使用,推荐在单线程环境下使用 HashMap 替代,如果需要多线程使用则用 ConcurrentHashMap 替代。

5. 如何决定使用 HashMap 还是 TreeMap?对于在 Map 中插入、删除、定位一个元素这类操作,HashMap 是最好的选择,因为相对而言 HashMap 的插入会更快,但如果你要对一个 key 集合进行有序的遍历,那 TreeMap 是更好的选择。

6. 说一下 HashMap 的实现原理?HashMap 基于 Hash 算法实现的,我们通过 put(key,value)存储,get(key)来获取当传入 key 时,HashM网站名词解释词ap 会根据 key. hashCode() 计算出 hash 值,根据 hash 值将 value 保存在 bucket 里。

当计算出的 hash 值相同时,我们称之为 hash 冲突,HashMap 的做法是用链表和红黑树存储相同 hash 值得 value当 hash 冲突的个数比较少时,使用链表否则使用红黑树7. 说一下 HashSet 的实现原理?

HashSet 是基于 HashMap 实现的,HashSet 底层使用 HashMap 来保存所有元素,因此 HashSet 的实现比较简单,相关 HashSet 的操作,基本上都是直接调用底层 HashMap 的相关方法来完成,Hash网站名词解释词Set 不允许重复的值。

8. ArrayList 和 LinkedList 的区别是什么?数据结构实现:ArrayList 是动态数组的数据结构实现,而 LinkedList 是双向链表的数据结构实现随机访问效率:ArrayList 比 LinkedList 在随机访问的时候效率要高,因为 LinkedList 是线性的数据存储方式,所以需要移动指针从前往后依次查找。

增加和删除效率:在非首尾的增加和删除操作,LinkedList 要比 ArrayList 效率要高,因为 ArrayList 增删操作要影响数组内的其他数据的下标综合来说,在需要频繁读取集合中的元素时,更推荐使用 ArrayLis网站名词解释词t,而在插入和删除操作较多时,更推荐使用 LinkedList。

9. 如何实现数组和 List 之间的转换?数组转 List:使用 Arrays. asList(array) 进行转换List 转数组:使用 List 自带的 toArray() 方法代码示例:// list to array

List list = new ArrayList(); list. add("王磊"); list. add("的博客"); list. toArray(); // array to list

String[] array = new Stri网站名词解释词ng[]{"王磊","的博客"}; Arrays. asList(array); 10. ArrayList 和 Vector 的区别是什么?线程安全:Vector 使用了 Synchronized 来实现线程同步,是线程安全的,而 ArrayList 是非线程安全的。

性能:ArrayList 在性能方面要优于 Vector扩容:ArrayList 和 Vector 都会根据实际的需要动态的调整容量,只不过在 Vector 扩容每次会增加 1 倍,而 ArrayList 只会增加 50%。

11. Array 和 ArrayList 有何区别?Array 可以存储网站名词解释词基本数据类型和对象,ArrayList 只能存储对象Array 是指定固定大小的,而 ArrayList 大小是自动扩展的Array 内置方法没有 ArrayList 多,比如 addAll、removeAll、iteration 等方法只有 ArrayList 有。

12. 在 Queue 中 poll()和 remove()有什么区别?相同点:都是返回第一个元素,并在队列中删除返回的对象不同点:如果没有元素 poll()会返回 null,而 remove()会直接抛出 NoSuchElementException 异常。

代码示例:Queue queue = new LinkedList();网站名词解释词 queue. offer("string"); // add System. out. println(

queue. poll()); System. out. println(queue. remove()); System. out. println(queue. size()); 13. 哪些集合类是线程安全的?

Vector、Hashtable、Stack 都是线程安全的,而像 HashMap 则是非线程安全的,不过在 JDK 1.5 之后随着 Java. util. concurrent 并发包的出现,它网站名词解释词们也有了自己对应的线程安全类,比如 HashMap 对应的线程安全类就是 ConcurrentHashMap。

14. 迭代器 Iterator 是什么?Iterator 接口提供遍历任何 Collection 的接口我们可以从一个 Collection 中使用迭代器方法来获取迭代器实例迭代器取代了 Java 集合框架中的 Enumeration,迭代器允许调用者在迭代过程中移除元素。

15. Iterator 怎么使用?有什么特点?Iterator 使用代码如下:List list = new ArrayList<>(); Iterator it = list. iterator网站名词解释词();

while(it. hasNext()){ String obj = it. next(); System. out. println(obj); } Iterator 的特点是更加安全,因为它可以确保,在当前遍历的集合元素被更改的时候,就会抛出

ConcurrentModificationException 异常16. Iterator 和 ListIterator 有什么区别?Iterator 可以遍历 Set 和 List 集合,而 ListIterator 只能遍历 List。

Iterator 只能单向遍历,而 Lis网站名词解释词tIterator 可以双向遍历(向前/后遍历)ListIterator 从 Iterator 接口继承,然后添加了一些额外的功能,比如添加一个元素、替换一个元素、获取前面或后面元素的索引位置。

17. 怎么确保一个集合不能被修改?可以使用 Collections. unmodifiableCollection(Collection c) 方法来创建一个只读集合,这样改变集合的任何操作都会抛出 Java. lang.

UnsupportedOperationException 异常示例代码如下:List list = new ArrayList<>(); list. add("x"网站名词解释词); Collection clist = Collections. unmodifiableCollection(。

list); clist. add("y"); // 运行时此行报错 System. out. println(list. size());

扫描二维码推送至手机访问。

版权声明:本文由海南拓宏网络科技工作室发布,如需转载请注明出处。

本文链接:http://4blc.com/post/16072.html

分享给朋友:

“java八股文在哪看(java八股文要看多久)” 的相关文章

java面试遇到的技术难题(java难点面试题)

今天给各位分享 Java面试变得难,有2个原因1、疫情所致在大环境都不好的情况下,大厂以及各大公司都在裁员缩小规模岗位变得少了,面试的要求自然就提高了能够被裁的基本上都是一些可替代性工作了甚至听说一些公司出现了骚操作,尤其是初创公司。 从人才市场上只收实习生,同时录用2个或...

计算机科学与技术是什么专业干什么的(计算机科学与技术是学什么呢)

本篇文章给大家谈谈 计算机科学与技术也叫做CS专业,顾名思义,是学习计算机相关的科学原理和专业技术的一门学科那么它和其他计算机专业,如软件工程、网络工程、信息管理与系统专业等有什么不同呢?我自己也是计算机科学与技术专业的,所以我深有体会在踏入这个专业之前,大家的一些疑惑,下面我就为...

java面向对象编程的三大特征(java面向对象五大设计原则)

今天给各位分享 写在前面:面向对象的三个基本要素和五个基本原则,很早以前就知道.但是一直没有当做很重要的东西去理解,以为就是概念性的东西知道就好了.最近再看代码重构的知识.发现要想写出干净的代码,就一定要遵守这五个原则. 单一职责原则(Single-Resposibilit...

stringbuffer和stringbuilder(string,stringbuffer,stringbudilder区别)

今天给各位分享 StringBuffer和Stringbuuuilder都是java中的字符串缓冲区类,他们的主要作用是用来存储和操作字符串他们的主要区别在于:线程安全和性能;相同点在于:可变性和初始容量线程是否安全和性能。 StringBuffer是线程安全的,所有的方法...

线程与进程的根本区别(线程和进程的区别与联系)

本篇文章给大家谈谈 经常有同学分不清进程和线程的区别,今天刚好有空就整理了一份文章,方便大家区分进程和线程.定义不同:进程是操作系统资源分配的基本单位(说直白点就是指正在运行的程序),而线程是任务调度和执行的基本单位(说直白点就是程序中的一条执行线路)Java开发学习中线程和进程的...

动力节点java课堂笔记(动力节点it培训官网)

本文分享给大家的是: 原标题:动力节点Java培训,一家只教Java的培训机构据求职网发布的《q1中高端人才就业趋势大数据报告》显示,今年一季度,55.87%的职场人有跳槽计划,其中65.34%的职场人选择跨行业跳槽从简历投递的领域来看,it和互联网行业投递的人更多。 另一...