发布时间:2025-12-10 23:50:24 浏览次数:12
1、各种框架中的应用
Spring框架的事务管理中使用ThreadLocal来管理连接,每个线程是单独的连接,当事务失败时不能影响到其他线程的事务过程或结果,还有大家耳闻目睹的ORM框架、Mybatis也是用ThreadLocal管理,SqlSession也是如此。
//SpringTransactionSynchronizationManager类@OverrideprotectedvoiddoBegin(Objecttransaction,TransactionDefinitiondefinition){DataSourceTransactionObjecttxObject=(DataSourceTransactionObject)transaction;Connectioncon=null;try{//此处省略N行代码if(txObject.isNewConnectionHolder()){//绑定数据库连接到线程中TransactionSynchronizationManager.bindResource(obtainDataSource(),txObject.getConnectionHolder());}}catch(Throwableex){if(txObject.isNewConnectionHolder()){//当发生异常时,移除线程中的连接DataSourceUtils.releaseConnection(con,obtainDataSource());txObject.setConnectionHolder(null,false);}thrownewCannotCreateTransactionException("CouldnotopenJDBCConnectionfortransaction",ex);}}2、防止内存泄漏
通常我们是使用如下的方式操作ThreadLocal,在使用完threadlocal后一定要remove掉,防止内存泄露。
privatestaticfinalThreadLocal<LoginUser>loginUserLocal=newThreadLocal<LoginUser>();publicstaticLoginUsergetLoginUser(){returnloginUserLocal.get();}publicstaticvoidsetLoginUser(LoginUserloginUser){loginUserLocal.set(loginUser);}publicstaticvoidclear(){loginUserLocal.remove();}//在使用完后一定要清理防止内存泄露try{loginUserLocal.set(loginUser);//执行其他业务逻辑}finally{loginUserLocal.remove();}