`
newleague
  • 浏览: 1500909 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类

ThreadLocal类解释(二)

阅读更多

通常在多线程中,当使用ThreadLocal维护变量时,ThreadLocal为每个使用该变量的线程提供独立的变量副本,所以每一个线程都可以独立地改变自己的副本,而不会影响其它线程所对应的副本

      实现线程本地类其实不难:以当前线程为key,要保存的对象为value

      public class ThreadLocalSample {

           private Map map = Collections.synchronizedMap(new HashMap());

          

           public void set(Object value) {

               map.put(Thread.currentThread(), value);

           }

           public Object get() {

               Object value = map.get(Thread.currentThread());

               return value;

           }

      }

      ThreadLocal可用在Servlet的过滤器中,比如:每一个请求都由一个Connection来操作数据库,由于Servlet只有一个实例,所以应该是每个线程用一个连接,而不是所有线程用一个Connection,因此需要用到ThreadLocal类;由于Servlet是在Filter链的调用中点执行,即Filter1->Filter2->...->Servlet->Filter2->Filter1,因此:可以用一个Filter,在这个Filter调用下一个Filter前初始化连接,并将其放入ThreadLocal中,在调用又回到这个Filter时,得到连接并关闭。

      代码如下:

      public class TransactionManageFilter implements Filter {

              private FilterConfig config;

              public void init(FilterConfig config) throws ServletException {
                  this.config = config;

              }

              public void destroy() {
                 config = null;
              }

             
               public void doFilter(ServletRequest request, ServletResponse response,
                                              FilterChain chain) throws IOException, ServletException {

                      Connection conn = ConnectionManager.currentConnection();

                      try {

                            conn.setAutoCommit(false);

                            chain.doFilter(request, response, chain);

                            conn.commit();

                      } catch (Exception e) {

                            conn.rollback();

                      } finally {

                            try {

                               conn.setAutoCommit(true);

                               conn.close();

                               ConnectionManager.removeConnection();

                            } catch (Exception e) {}

                      }

               }

      }

      public class ConnectionManager {

          private static ThreadLocal currConn = new ThreadLocal();

      

          public static Connection currentConnection() {

              Object obj = currConn.get();

              if (obj != null) {

                 return (Connection)obj;

              } else {

                  Connection conn = ConnectionFactory.getConnection();

                  currConn.set(conn);

                  return conn;

              }

          }

         public static void removeConnection() {

             Object obj = currConn.get();

             if (obj != null) {

                currConn.set(null);

             }

        }

     }

 

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/teedry/archive/2010/01/11/5177709.aspx

分享到:
评论

相关推荐

    入研究java.lang.ThreadLocal类.docx

    #### 二、API 解释 ##### ThreadLocal() **用途**:创建一个新的 ThreadLocal 实例。 **示例代码**: ```java ThreadLocal<String> threadLocal = new ThreadLocal(); ``` ##### T get() **用途**:返回当前...

    Java单线程ThreadLocal串值问题解决方案

    在Java中,ThreadLocal可以通过ThreadLocal类的实例来实现线程间隔离的变量访问。例如,在示例代码中,我们使用了ThreadLocal<String> currentUid = ThreadLocal.withInitial(() -> null);来定义一个ThreadLocal变量...

    详细介绍java中的内部类共8页.pdf.zip

    以下是对Java内部类的详细解释: 一、内部类的分类: 1. 成员内部类:在类的外部定义,与类的成员变量和方法处于同一层次,可以访问外部类的所有成员,包括私有成员。 2. 局部内部类:在方法或作用域内定义的类,...

    浅谈SpringMVC HandlerInterceptor诡异问题排查

    在这个例子中,我们可以发现有一个UserContext的静态类,它使用ThreadLocal来保存用户的登录信息。这个类提供了get和clear方法来获取和清理用户的登录信息。 在拦截器中,我们可以发现调用了UserContext.set方法来...

    mat java 分析 文件 dump

    如果发现`ThreadLocal`绑定的`Dao`类占用了大量内存,则需要进一步检查此类是否合理使用了`ThreadLocal`机制。通常情况下,不当使用`ThreadLocal`会导致每个线程保留大量不必要的数据,从而增加内存负担。 ##### 2....

    JAVA程序设计------

    2. **第二章:类与对象** 类是面向对象编程的基础,是描述对象的模板。而对象是类的实例,包含数据(成员变量)和行为(方法)。这一章将深入讲解如何定义类,创建对象,以及理解封装、继承和多态等面向对象的核心...

    Java 7并发编程实战手册

    1. **线程局部变量ThreadLocal**:讲解ThreadLocal类的用途及其如何帮助减少内存开销并简化代码编写。 2. **不可变对象**:解释为什么使用不可变对象可以提高并发程序的性能,并给出如何创建不可变对象的建议。 3....

    Java 面试题

    面试者需要掌握线程创建的方式、线程同步机制(synchronized关键字、ReentrantLock等)、volatile关键字的作用以及ThreadLocal类的用途。 #### 二、高级特性与应用 1. **反射机制** - 反射是Java提供的一种能在...

    JAVA核心面试知识整理

    - 算法:排序(冒泡、选择、插入、快速、归并、堆排序等)、查找(顺序、二分、哈希查找)、递归、动态规划、贪心算法、回溯法等。 2. **设计模式**: - 创建型:单例、工厂、抽象工厂、建造者、原型模式。 - ...

    阿里巴巴Java开发手册.zip

    2. 注释:注释应简洁明了,解释代码逻辑,而不是代码本身的内容。类、方法、变量上方应有Javadoc注释。 3. 类与接口:类名使用全大写字母单词组合,接口名推荐以"I"开头,如`IUserService`。 二、异常处理 1. 异常...

    java面试题大全 java面试

    Java多线程是面试中的热点,会考察synchronized关键字、volatile、ThreadLocal、线程池(ExecutorService)等。面试官可能让你解释并发编程中的死锁、活锁、饥饿状态等概念,并要求设计线程安全的代码。 五、IO/NIO...

    汪文君高并发编程实战视频资源全集

    │ 高并发编程第二阶段05讲、一个解释volatile关键字作用最好的例子.mp4 │ 高并发编程第二阶段06讲、Java内存模型以及CPU缓存不一致问题的引入.mp4 │ 高并发编程第二阶段07讲、CPU以及CPU缓存的结构,解决高速...

    汪文君高并发编程实战视频资源下载.txt

    │ 高并发编程第二阶段05讲、一个解释volatile关键字作用最好的例子.mp4 │ 高并发编程第二阶段06讲、Java内存模型以及CPU缓存不一致问题的引入.mp4 │ 高并发编程第二阶段07讲、CPU以及CPU缓存的结构,解决高速...

    Core Java Vol 1 & Vol 2

    3. **多线程**:涵盖线程的创建、同步、通信,以及ThreadLocal和并发工具类的使用。 4. **网络编程**:介绍套接字(Socket)编程,以及服务器端和客户端的实现。 5. **反射机制**:讲解如何在运行时动态获取类的...

    java习题(20211007012756).pdf

    实验二:类与对象 此实验旨在教授面向对象编程的基础,包括: 1. 定义类,理解类的属性(fields)和方法(methods)。 2. 创建和使用对象,理解对象的实例化过程。 3. 学习访问修饰符(public, private, protected, ...

    多线程01(md文档+代码)多线程01(md文档+代码)(超详细)

    本资源包中的Markdown文档将详细解释上述概念,并通过实际代码案例进行演示,帮助读者更好地理解和应用多线程技术。代码示例可能包括线程创建、同步机制的应用、线程通信的实现以及线程池的使用等,读者可以通过运行...

    阿里巴巴开发手册(嵩山版)下载

    2. 注释规范:提供清晰的函数和类注释,用Javadoc格式,对于复杂的逻辑或重要的代码段要进行详细解释。 3. 类与接口:合理设计类和接口,避免过多的抽象类,优先考虑接口实现多态。 二、异常处理 1. 异常捕获:避免...

Global site tag (gtag.js) - Google Analytics