ThreadLocal 解决多线程程序的并发问题+事务处理

ThreadLocal 本地线程变量:

private static ThreadLocal<Connection> tl = new ThreadLocal<Connection>();
  tl.get():获取的就是当前线程中map{tl:conn}中的conn
  tl.set(conn):向当前线程中的map中保存一个元素{tl:conn}
  tl.remove():从当前线程中的map移除key为tl的元素
  initialValue():当调用get()获取当前线程的map中元素时,如果不存在,则调用该方法创建一个,并保存到map中

 

 

 1 import java.sql.Connection;
 2 import java.sql.SQLException;
 3 
 4 public class TranManager {
 5     private static ThreadLocal<Connection> tl=
 6                     new ThreadLocal<Connection>(){
 7         /**
 8          * 内部方法 
 9          * 返回回该线程局部变量的初始值
10          * 初始化线程,每次get()或者set(object)的时候会被调用。
11          */
12         protected Connection initialValue() {
13             try {
14                 return DaoUtils.getConn();
15             } catch (Exception e) {
16                 e.printStackTrace();
17                 return null;
18             }
19         }
20     };
21     private TranManager(){}
22     public static  Connection getConn(){
23         return tl.get();
24     }
25     /**
26      * @return 开启手动提交事务,
27      * @false: 将sql命令交给应用程序管理 
28      */
29     public static void startTran(){
30         try {
31             tl.get().setAutoCommit(false);
32         } catch (SQLException e) {
33             e.printStackTrace();
34         }
35     }
36     /**
37      * @return 回滚
38      */
39     public static void rollbackTran(){
40         try {
41             tl.get().rollback();
42         } catch (SQLException e) {
43             e.printStackTrace();
44         }
45     }
46     /**
47      * @return 执行
48      */
49     public static void commitTran(){
50         try {
51             tl.get().commit();
52         } catch (SQLException e) {
53             e.printStackTrace();
54         }
55     }
56     /**
57      * @return 关闭
58      */
59     public static void release(){
60         try {
61             tl.get().close();
62             tl.remove();//map{tl:conn}
63         } catch (SQLException e) {
64             e.printStackTrace();
65         }
66     }
67     /*public void rollbackTran(Savepoint sp){
68         try {
69             conn.rollback(sp);
70             conn.commit();
71         } catch (SQLException e) {
72             e.printStackTrace();
73         }
74     }*/
75 }

 

posted @ 2017-10-02 20:14  狂妄的老头  阅读(2195)  评论(0编辑  收藏  举报