搜索
写经验 领红包
 > 游戏

java多线程如何共享数据(java线程间数据共享)

导语:Java多线程数据共享神器ThreadLocal

ThreadLocal内部结构和作用

从ThreadLocal源码中可以看到其提供了3个方法,分别是get/set/remove。维护了一个ThreadLocalMap的数据结构。在多线程环境下能正确地获取共享的数据变量或值。

ThreadLocal应用原理

ThreadLocal提供了线程本地实例。每个线程在使用该变量时初始化一个完全独立的实例副本。保证了获取的变量正确性和可靠性。

ThreadLocal使用场景

ThreadLocal应用场景常见于:每个线程需要单独保存实例;Mybatis多数据源切换;Spring声明式事务的实现机制。

ThreadLocal面试问题

面试官比较喜欢问到的关于ThreadLocal的问题有以下:

1、说一下你理解的ThreadLocal数据结构和原理。

答案上面已分析。

2、ThreadLocal会导致内存泄漏吗?

回答:实际上ThreadLocalMap中使用的是弱引用,垃圾回收的时候会被清理掉的。一般情况下不会出现内存泄漏。但是特别极端情况会导致内存泄漏。比如:ThreadLocal引用被标记为null并且后续没有set/get/remove操作;线程一直不停的运行;触发了垃圾回收;

3、SpringMVC采用单例模式,如何保证多线程访问变量数据安全。

回答:可以通过定义ThreadLocal变量

本文内容由小苹整理编辑!