zoukankan      html  css  js  c++  java
  • ThreadLocal为什么要设计成private static

    https://www.zhihu.com/question/35250439

    结论:

    1 static 防止无意义多实例

    2 当static时,ThreadLocal ref生命延长-ThreadMap的key在线程生命期内始终有值-ThreadMap的value在线程生命期内不释放——故线程池下,static修饰TrheadLocal引用,必须(1)remove   或(2)手动  ThreadLocal ref = null

    两个例子:

    A      《多线程实战》上ThreadLocal的一个实例

    作者测试的顺序:

    1 创建10000个runnable对象放入max 10的线程池,创建10个Thread,即10个~Map;

    2 新建ThreadLocal(1)对象,调用get/set,产生10个SimpleDateFormat对象;

    3 static ThreadLocal red = null ,此时ThreadLocal对象仅有一个弱引用,在Thread.~Map中;

    4 第一次gc,回收了ThreadLocal对象,同时致使 Thread.~Map中存在10个key为null的value;

    5 再创建10000个runnable对象,放入线程池原先的10个线程;

    6 新建ThreadLocal(2)对象,调用set,触发新变量加入Thread.~Map,进而触发中key为null的value对象被置为可回收对象,原先的value对象与Thread的强引用断开

    7 第二次gc,正式回收被与Thread断开强引用的10个SimpleDateFormat对象

     

    B      模仿spring事务框架时的一个数据库连接例子

    Java事务处理全解析(四)—— 成功的案例(自己实现一个线程安全的TransactionManager)

    http://blog.csdn.net/huilangeliuxin/article/details/43446733

    这篇文章中有个实例:

    定义一个线程安全的SingleThreadConnectionHolder类如下:

    [java] view plain copy
    1. public class SingleThreadConnectionHolder  
    2. {  
    3.     private static ThreadLocal<ConnectionHolder> localConnectionHolder = new ThreadLocal<ConnectionHolder>();  
    4.              
    5.     public static Connection getConnection(DataSource dataSource) throws SQLException  
    6.     {  
    7.         return getConnectionHolder().getConnection(dataSource);  
    8.     }  
    9.              
    10.     public static void removeConnection(DataSource dataSource)  
    11.     {  
    12.         getConnectionHolder().removeConnection(dataSource);  
    13.     }  
    14.              
    15.     private static ConnectionHolder getConnectionHolder()  
    16.     {  
    17.         ConnectionHolder connectionHolder = localConnectionHolder.get();  
    18.         if (connectionHolder == null)  
    19.         {  
    20.             connectionHolder = new ConnectionHolder();  
    21.             localConnectionHolder.set(connectionHolder);  
    22.         }  
    23.         return connectionHolder;  
    24.     }  
    25.              
    26. }  

     

    可以看到,每次事务提交后,都调用remove,防止连接泄露

  • 相关阅读:
    uCOS-II 学习笔记之任务管理--------任务控制块OS_TCB
    uCOS-II 学习笔记之事件管理--------信号量管理的学习
    格子计划
    phpcms二次开发之base.php的桥梁作用
    [leedcode 215] Kth Largest Element in an Array
    [leedcode 214] Shortest Palindrome
    [leedcode 213] House Robber II
    [leedcode 212] Word Search II
    [leedcode 211] Add and Search Word
    [leedcode 210] Course Schedule II
  • 原文地址:https://www.cnblogs.com/tiancai/p/13141234.html
Copyright © 2011-2022 走看看