博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ThreadLocal变量——转不过的一个弯(咬文嚼字型)
阅读量:5091 次
发布时间:2019-06-13

本文共 1328 字,大约阅读时间需要 4 分钟。

  这次的随笔只是一时兴起,纪念下自己不好使的脑子?!

  网上介绍ThreadLocal变量的博文有很多,解释的基本都差不多,这边也就不再啰嗦了,下面列出一些介绍的链接,方便大家查阅。

  1、

  2、

  3、

  .......

  上面解释的都很好,大家可以放心点击。

  咻~回到正题,经常能在网上看到“ThreadLocal解决多线程变量共享问题”这样的说法。起初刚在接触ThreadLocal变量的时候,一直把这个“变量共享”当成是多个线程共同操作变量的情况,比如有一个从1数到1亿的任务,由5个线程来完成,线程a数了1、2、3,然后又有线程b数了4、5、6、7、8,此处省略,而我觉得这里从1到1亿的value是真正意义上的“共享”。

  而ThreadLocal变量,如果非要扯上“共享”的意思,那也只有变量的初始值共享了,各个线程只是共享了ThreadLocal的初始值。因为大家都知道,各个线程对于ThreadLocal变量其实都是各干各的,互相之间互不干扰。所以我觉得这算不上“共享”一说。当然这只是一个文字游戏,并非技术上的问题,在这边提出来也希望能够帮助到跟我一样有这个困扰的同学。

  看一下ThreadLocal的应用场景就能明白:

  1、数据库连接  

private static ThreadLocal < Connection > connectionHolder = new ThreadLocal < Connection > () {    public Connection initialValue() {        return DriverManager.getConnection(DB_URL);    }};public static Connection getConnection() {    return connectionHolder.get();}

  2、Seesion管理

private static final ThreadLocal threadSession = new ThreadLocal();public static Session getSession() throws InfrastructureException {    Session s = (Session) threadSession.get();    try {        if (s == null) {            s = getSessionFactory().openSession();            threadSession.set(s);        }    } catch (HibernateException ex) {        throw new InfrastructureException(ex);    }    return s;}

  以上的Connection和Session都是互相不干扰,每个线程各自持有的。

转载于:https://www.cnblogs.com/JcWft/p/8890747.html

你可能感兴趣的文章
第二阶段冲刺-01
查看>>
BZOJ1045 HAOI2008 糖果传递
查看>>
JavaScript 克隆数组
查看>>
eggs
查看>>
python3 生成器与迭代器
查看>>
java编写提升性能的代码
查看>>
《Genesis-3D开源游戏引擎完整实例教程-跑酷游戏篇03:暂停游戏》
查看>>
CPU,寄存器,一缓二缓.... RAM ROM 外部存储器等简介
查看>>
git .gitignore 文件不起作用
查看>>
Alan Turing的纪录片观后感
查看>>
IOS--沙盒机制
查看>>
使用 JointCode.Shuttle 访问任意 AppDomain 的服务
查看>>
sqlite的坑
查看>>
digitalocean --- How To Install Apache Tomcat 8 on Ubuntu 16.04
查看>>
【题解】[P4178 Tree]
查看>>
Mongo自动备份
查看>>
cer证书签名验证
查看>>
synchronized
查看>>
【深度学习】caffe 中的一些参数介绍
查看>>
Python-Web框架的本质
查看>>