温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Java中会遇见的面试题有哪些

发布时间:2021-05-08 09:30:10 来源:亿速云 阅读:123 作者:小新 栏目:编程语言

这篇文章给大家分享的是有关Java中会遇见的面试题有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

java基本数据类型有哪些

Java的基本数据类型分为:1、整数类型,用来表示整数的数据类型。2、浮点类型,用来表示小数的数据类型。3、字符类型,字符类型的关键字是“char”。4、布尔类型,是表示逻辑值的基本数据类型。

在准备面试的一段时间,我们需要对基本的理论知识做一个复习,尤其是一些反复会问到的知识点。相信在有所准备之后,大家在面试时也能增添不少的信心。

一、专业技能模块

1.集合

经常用到哪些 Map

这几种 Map 的区别

2.多线程、锁

线程池使用的是哪种

线程池参数怎么配置

3.网络

HTTPS 是怎么加密的

普通 Hash 和一致性 Hash 原理

4.Spring、Mybatis

Mybatis 中 # 和 $ 的区别

怎么防止SQL 注入

5.MySQL

MySQL 索引的数据结构

为什么使用 B+ 树,与其他索引相比有什么优点

6.JVM

运行时数据区

服务器使用的什么垃圾收集器

7.分布式

CAP 理论

BASE 理论

二、高频试题

1.HashMap和Hashtable各有什么特点,它们有什么区别?(必背题,超级重要)

(1)HashMap和Hashtable都实现了Map接口,但决定用哪一个之前先要弄清楚它们之间的分别。主要的区别有:线程安全性,同步(synchronization),以及速度。

(2)HashMap几乎可以等价于Hashtable,除了HashMap是非synchronized的,并可以接受null(HashMap可以接受为null的键值(key)和值(value),而Hashtable则不行)。

(3)HashMap是非synchronized,而Hashtable是synchronized,这意味着Hashtable是线程安全的,多个线程可以共享一个Hashtable;而如果没有正确的同步的话,多个线程是不能共享HashMap的。Java 5提供了ConcurrentHashMap,它是HashTable的替代,比HashTable的扩展性更好。

(4)另一个区别是HashMap的迭代器(Iterator)是fail-fast迭代器,而Hashtable的enumerator迭代器不是fail-fast的。所以当有其它线程改变了HashMap的结构(增加或者移除元素),将会抛出ConcurrentModificationException,但迭代器本身的remove()方法移除元素则不会抛出ConcurrentModificationException异常。但这并不是一个一定发生的行为,要看JVM。这条同样也是Enumeration和Iterator的区别。

由于Hashtable是线程安全的也是synchronized,所以在单线程环境下它比HashMap要慢。如果你不需要同步,只需要单一线程,那么使用HashMap性能要好过Hashtable。

(5)HashMap不能保证随着时间的推移Map中的元素次序是不变的。

2.Java集合类框架的基本接口

Java集合类提供了一套设计良好的支持对一组对象进行操作的接口和类。Java集合类里面最基本的接口有:

• Collection:代表一组对象,每一个对象都是它的子元素。

• Set:不包含重复元素的Collection。

• List:有顺序的collection,并且可以包含重复元素。

• Map:可以把键(key)映射到值(value)的对象,键不能重复

感谢各位的阅读!关于“Java中会遇见的面试题有哪些”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI