ThreadLocal变量——转不过的一个弯(咬文嚼字型…
2018-06-27 09:58:58来源:未知 阅读 ()
这次的随笔只是一时兴起,纪念下自己不好使的脑子??!
网上介绍ThreadLocal变量的博文有很多,解释的基本都差不多,这边也就不再啰嗦了,下面列出一些介绍的链接,方便大家查阅。
1、知乎上的解答
2、博客园上的解答
3、segmentfault上的解答
.......
上面解释的都很好,大家可以放心点击。
咻~回到正题,经常能在网上看到“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都是互相不干扰,每个线程各自持有的。
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:Java高级篇(二)——网络通信
下一篇:java整形中的缓存机制
- 深入解析ThreadLocal和ThreadLocalMap 2020-06-08
- 什么,容器太多操作不过来?我选择Docker Compose梭哈 2020-05-28
- 路径变量@PathVariable/请求参数@RequestParam的绑定以及@Re 2020-05-24
- JDK安装与配置环境变量 2020-05-19
- 快手最复杂的一次java面试,不过面试官很和蔼 2020-05-13
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash