温馨提示×

温馨提示×

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

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

ThreadLocal和ThreadPoolExecutor如何同时使用

发布时间:2021-12-04 09:56:30 来源:亿速云 阅读:160 作者:小新 栏目:大数据

这篇文章主要介绍ThreadLocal和ThreadPoolExecutor如何同时使用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

ThreadLocal会为每个线程保存一份成员变量的副本,而ThreadPoolExecutor是一些线程不断执行各种任务(线程复用)。比如,你让具有3个线程的ThreadPoolExecutor执行13个任务,那么有一个线程会执行5个任务,另外两个线程执行4个任务。那么,每个线程执行的这几个(5个或4个)任务,会共享ThreadLocal的数据备份。并不是每个任务有一个数据副本。

来段代码说明

TestNum类中定义sewNum这样一个ThreadLocal量,每个线程访问这个类时,都会有一个seqNum的副本。

ThreadLocal和ThreadPoolExecutor如何同时使用

定义一个任务,打印ThreadLocal变量值

ThreadLocal和ThreadPoolExecutor如何同时使用

在一个具有3个线程的线程池中,执行13个任务

ThreadLocal和ThreadPoolExecutor如何同时使用

输出结果,可以看到每个线程,都有一份ThreadLocal的数据备份。但是这些任务并没有独立的数据副本(同一线程执行的任务,共享同一个副本数据)

ThreadLocal和ThreadPoolExecutor如何同时使用

这就是文章开头提到的分库BUG产生的原因。程序员产生了每个任务都有一个数据副本的错觉。

以上是“ThreadLocal和ThreadPoolExecutor如何同时使用”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!

向AI问一下细节

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

AI