java基础面试

Hashmap和Treemap的区别

1、HashMap无序,TreeMap有序。都不是线程安全的。

2、HashMap覆盖了equals()方法和hashcode()方法,这使得HashMap中两个相等的映射返回相同的哈希值;TreeMap则是实现了SortedMap接口,使其有序。

3、HashMap的工作效率更高,而TreeMap则是基于树的增删查改。更推荐使用HashMap。

4、HashMap基于数组+链表+红黑树(jdk1.8之后)实现,TreeMap是基于红黑树实现。

HashMap和LinkedHashMap的区别?

1 HashMap 存储元素的顺序是无序的,而 LinkedHashMap 则是按照插入顺序存储元素的。

2 性能:由于需要维护一个链表,LinkedHashMap 在性能上略微慢一些,但通常差别不大。在性能要求较高的场合下建议使用 HashMap。

3 内存消耗:LinkedHashMap 在内存占用上比 HashMap 稍微多一点,因为需要存储额外的链表信息

HashMap为什么线程不安全?

HashMap会进行resize操作,在resize操作的时候会造成线程不安全。

1、put的时候导致的多线程数据不一致。

2、get操作可能因为resize而引起死循环

什么是幂等性?

就是用户对于同一操作发起的一次请求或者多次请求的结果是一致的,不会因为多次点击而产生了副作用。

在增删改查4个操作中,尤为注意就是增加或者修改,查询对于结果是不会有改变的,删除只会进行一次,用户多次点击产生的结果一样,修改在大多场景下结果一样,增加在重复提交的场景下会出现。

线程池的核心参数有哪些?

corePoolSize:核心线程数。

maximumPoolSize:最大线程数。

keepAliveTime:空闲线程存活时间。

TimeUnit:时间单位。

BlockingQueue:线程池任务队列。

ThreadFactory:创建线程的工厂。

RejectedExecutionHandler:拒绝策略。

拒绝策略有哪些?

AbortPolicy:拒绝并抛出异常。

CallerRunsPolicy:使用当前调用的线程来执行此任务。

DiscardOldestPolicy:抛弃队列头部(最旧)的一个任务,并执行当前任务。

DiscardPolicy:忽略并抛弃当前任务。

线程池的默认策略是 AbortPolicy 拒绝并抛出异常。

什么是事务?有什么用?

事务的特性原子性、一致性、隔离性和持续性 (ACID)这几种属性,以使数据能够正确地提交到数据库中。

1)原子性(Atomicity)原子性是指事务是一个不可分割的工作单位,事务中的操作 要么都发生,要么都不发生。

2)一致性(Consistency)一个事务中,事务前后数据的完整性必须保持一致。

3)隔离性(Isolation)多个事务,事务的隔离性是指多个用户并发访问数据库时, 一个用户的 事务不能被其它用户的事务所干扰,多个并发事务之间数据要相互隔离。

4)持久性(Durability)持久性是指一个事务一旦被提交,它对数据库中数据的改变 就是永久性的,接下来即使数据库发生故障也不应该对其有任何影响。

事务的并发会产生的问题有哪些?

1.脏读

2.不可重复读

3 幻读

不可重复读和幻读的区别?

不可重复读是指在同一查询事务中多次进行,由于其他提交事务所做的修改和删除,每次返回不同的结果集,此时发生不可重复读

幻读是指在同一查询事务中多次进行,由于其他提交的事务所做的插入操作,每次返回不同的结果集,此时发生幻读表面上看,区别就在于不可重复读能看见其他事务提交的修改和删除,而幻读能看见其他事务提交的插入

spring 事务隔离级别?

1.default:(默认)

默认隔离级别,使用数据库默认的事务隔离级别

2.read_uncommitted:(读未提交)

这是事务最低的隔离级别,他允许另外一个事务可以看到这个事务未提交的数据,这种隔离级别会产生脏读,不可重复读和幻读

3.read_committed(读已提交)

保证一个事务修改的数据提交后才能被另外一个事务读取,另外一个事务不能读取该事务未提交的数据.这种事务隔离级别可以避免脏读,但是可能会出现不可重复读和幻读

4.repeatable_read(可重复读)

这种事务级别可以防止脏读,不可重复读.但是可能出现幻读.他除了保证一个事务不能读取另一个事务未提交的数据外,还保证了不可重复读

5.Serializable 串行化

这是花费最高代价但是最可靠的事务隔离级别。事务被处理为顺序执行。防止了脏读、不可重复读、幻读

相关推荐
Kuo-Teng6 分钟前
LeetCode 73: Set Matrix Zeroes
java·算法·leetcode·职场和发展
初见无风6 分钟前
3.4 Boost库intrusive_ptr智能指针的使用
开发语言·boost
王元_SmallA8 分钟前
服务器公网IP、私网IP、弹性IP是什么?区别与应
java·后端
程序猿20239 分钟前
Python每日一练---第六天:罗马数字转整数
开发语言·python·算法
葵续浅笑28 分钟前
LeetCode - 杨辉三角 / 二叉树的最大深度
java·数据结构·算法·leetcode
装不满的克莱因瓶38 分钟前
【Java架构师】各个微服务之间有哪些调用方式?
java·开发语言·微服务·架构·dubbo·restful·springcloud
杨筱毅44 分钟前
【穿越Effective C++】条款13:以对象管理资源——RAII原则的基石
开发语言·c++·effective c++
N 年 后1 小时前
cursor和传统idea的区别是什么?
java·人工智能·intellij-idea
CodeLongBear1 小时前
从Java后端到Python大模型:我的学习转型与规划
java·python·学习
Miraitowa_cheems1 小时前
LeetCode算法日记 - Day 94: 最长的斐波那契子序列的长度
java·数据结构·算法·leetcode·深度优先·动态规划