- 浏览: 600029 次
- 性别:
- 来自: 厦门
文章分类
- 全部博客 (669)
- oracle (36)
- java (98)
- spring (48)
- UML (2)
- hibernate (10)
- tomcat (7)
- 高性能 (11)
- mysql (25)
- sql (19)
- web (42)
- 数据库设计 (4)
- Nio (6)
- Netty (8)
- Excel (3)
- File (4)
- AOP (1)
- Jetty (1)
- Log4J (4)
- 链表 (1)
- Spring Junit4 (3)
- Autowired Resource (0)
- Jackson (1)
- Javascript (58)
- Spring Cache (2)
- Spring - CXF (2)
- Spring Inject (2)
- 汉字拼音 (3)
- 代理模式 (3)
- Spring事务 (4)
- ActiveMQ (6)
- XML (3)
- Cglib (2)
- Activiti (15)
- 附件问题 (1)
- javaMail (1)
- Thread (19)
- 算法 (6)
- 正则表达式 (3)
- 国际化 (2)
- Json (3)
- EJB (3)
- Struts2 (1)
- Maven (7)
- Mybatis (7)
- Redis (8)
- DWR (1)
- Lucene (2)
- Linux (73)
- 杂谈 (2)
- CSS (13)
- Linux服务篇 (3)
- Kettle (9)
- android (81)
- protocol (2)
- EasyUI (6)
- nginx (2)
- zookeeper (6)
- Hadoop (41)
- cache (7)
- shiro (3)
- HBase (12)
- Hive (8)
- Spark (15)
- Scala (16)
- YARN (3)
- Kafka (5)
- Sqoop (2)
- Pig (3)
- Vue (6)
- sprint boot (19)
- dubbo (2)
- mongodb (2)
最新评论
首先,ThreadLocal 不是用来解决共享对象的多线程访问问题的,一般情况下,通过ThreadLocal.set() 到线程中的对象是该线程自己使用的对象,其他线程是不需要访问的,也访问不到的。各个线程中访问的是不同的对象。
ThreadLocal可以为每个线程维护自己的变量,对于多线程使用同一对象可以起到管理作用。
在UserProcess中多个线程引用的同一个UserDAO,在线程运行后所有的语句都是通过一个Connection执行。
问题:
1、多个线程使用同一个conn效率比较低,存在数据共享问题。影响效率。
改进:
1、希望UserDAO中为每个线程开立一个conn,各线程使用自己的连接执行sql
改进后的代码
改动后每个线程都会维护自己的conn,userDAO变成线程安全的。
synchronized 是解决多个线程访问同一个变量
ThreadLocal 是每个线程维护自己专用的变量
两者使用场景不一样,作用也不一样。
转自:http://guoba6688-sina-com.iteye.com/blog/721383
ThreadLocal可以为每个线程维护自己的变量,对于多线程使用同一对象可以起到管理作用。
package com.koubei.Observable; import com.sun.org.apache.xalan.internal.xsltc.compiler.sym; public class UserProcess implements Runnable{ private UserDAO userDAO; public UserProcess(UserDAO userDAO){ this.userDAO = userDAO; } public void run() { // TODO Auto-generated method stub for(int i=0; i<1000; i++){ userDAO.insertUser(getUser()); } } public static void main(String[] args) { UserDAO userDAO = new UserDAO(); new Thread(new UserProcess(userDAO)).start(); new Thread(new UserProcess(userDAO)).start(); new Thread(new UserProcess(userDAO)).start(); } }
package com.koubei.Observable; import java.sql.Connection; public class UserDAO { private Connection conn = null; public UserDAO(){ } public void insertUser(User user){ getConn().prepareStatement(sql); //jdbc 操作 } public synchronized Connection getConn(){ if (conn == null) { try { Class.forName("com.mysql.jdbc.Driver"); CONN = DriverManager.getConnection("jdbc:mysql://" + DB_IP + ":" + "3306" + "/" + DB_NAME + "?useUnicode=true&characterEncoding=gbk", DB_USER, DB_PASSWORD); } catch (Exception ex) { ex.printStackTrace(); } } return conn; } }
在UserProcess中多个线程引用的同一个UserDAO,在线程运行后所有的语句都是通过一个Connection执行。
问题:
1、多个线程使用同一个conn效率比较低,存在数据共享问题。影响效率。
改进:
1、希望UserDAO中为每个线程开立一个conn,各线程使用自己的连接执行sql
改进后的代码
package com.koubei.Observable; import java.sql.Connection; import java.sql.DriverManager; import java.sql.SQLException; public class UserDAO { private static ThreadLocal<Connection> connThreadLocal = new ThreadLocal<Connection>(); public UserDAO(){ } public void insertUser(User user){ getConnection().prepareStatement(sql); //jdbc 操作 } public Connection getConnection(){ if (connThreadLocal.get() == null) { Connection conn = getConn(); connThreadLocal.set(conn); return conn; } return connThreadLocal.get(); } public synchronized Connection getConn(){ try{ Class.forName("com.mysql.jdbc.Driver"); return DriverManager.getConnection("jdbc:mysql://" + DB_IP + ":" + "3306" + "/" + DB_NAME + "?useUnicode=true&characterEncoding=gbk", DB_USER, DB_PASSWORD); }cache(SQLException e){ e.printStackTrace(); } return null; } }
改动后每个线程都会维护自己的conn,userDAO变成线程安全的。
synchronized 是解决多个线程访问同一个变量
ThreadLocal 是每个线程维护自己专用的变量
两者使用场景不一样,作用也不一样。
转自:http://guoba6688-sina-com.iteye.com/blog/721383
发表评论
文章已被作者锁定,不允许评论。
-
java WeakHashMap学习(key是弱引用)
2018-06-21 09:31 1232在Java集合中有一种特殊的Map类型:WeakHashMap ... -
java HashMap TreeMap(key顺序) LinkedHashMap(插入顺序)学习
2018-06-07 10:27 953java为数据结构中的映射定义了一个接口java.util.M ... -
java RESTful 详解
2018-04-27 11:35 643(1)每一个URI代表一种资源,独一无二; (2)客户端 ... -
java 通过HttpsUrlConnection访问接口数据
2018-04-19 11:25 990server: ssl: key-stor ... -
java 使用多线程的场景总结
2018-04-10 14:35 1704在一个高并发的网站中,多线程是必不可少的。下面先说一下多线程在 ... -
java Enum枚举设置
2018-04-10 10:55 480/** * 数据状态:0:无效,1:有效 **/ ... -
java RestTemplate访问restful服务
2018-03-01 15:02 1622REST的基础知识 当谈论REST时,有一种常见的错误就是将其 ... -
java FYOpenApi实现短信发送
2018-01-02 17:10 11741.配置文件 sms.OpenUrl = http://s ... -
java JSONObject序列化包含Date类型数据的Java对象
2017-12-26 16:31 1617如果Date.class无法进行转换则使用Timestamp. ... -
java 用HttpsURLConnection进行传递中文时错误总结
2017-12-07 16:42 654传递中文时需要用Writer而不是OutputStream ... -
java 内存泄漏
2017-11-27 13:51 4961.内存溢出 out of memory ... -
ActiveMQ 三种发送消息方式(同步,异步,单向)
2017-11-17 10:25 2453MQ 发送普通消息有三种实现方式:可靠同步发送、可靠异步发送、 ... -
java Guava ListenableFuture实现线程回调功能
2017-11-14 10:17 1775java Future具有局限性。在实际应用中,当需要下 ... -
java Curator实现分布式锁
2017-09-05 14:39 1090Curator实现分布式锁主要依赖于zookeeper ... -
java Guava工具集学习(强大)
2017-09-05 10:28 433import java.util.Iterator ... -
java CyclicBarrier进行并发编程
2017-08-25 15:44 673CyclicBarrier允许一组线程相互等待达到一个公共的障 ... -
java 几种性能优化的总结
2017-08-23 14:08 3251、使用StringBuilder 一般 ... -
java 使用kyro进行高性能序列化对象和集合
2017-08-23 14:05 2152import java.io.ByteArrayInp ... -
java 对重复电话号码进行排除的优化(排序和前后对比)
2017-08-22 14:14 7911.先对10万数据排序; 2.对比前后两条数据 ; 3.筛 ... -
ActiveMQ 结合Spring进行数据同步
2017-07-19 15:27 584注意事项hibernate配置文件必须设置自动提交否则不能插入 ...
相关推荐
Java中的ThreadLocal是一种特殊的技术,它为每个线程提供了一个独立的变量副本,避免了多线程间的直接共享,从而简化了并发编程的复杂性。ThreadLocal不是一种同步机制,而是设计来解决线程间数据隔离问题的工具。 ...
线程本地存储,如 `ThreadLocal` 类,提供了线程安全的数据结构,使得每个线程拥有自己的副本,避免了数据竞争问题。 #### 四、Java线程:线程状态的转换 - **线程的状态** Java线程的状态包括新建 (`NEW`)、...
Java 线程本地变量 ThreadLocal 详解 ThreadLocal 是 Java 中的一个类,提供了线程安全的对象封装,用于解决多线程访问数据的冲突问题。ThreadLocal 的主要目的是为每个线程提供一个变量副本,从而隔离了多个线程...
ThreadLocal,直译为“线程本地”或“本地线程”,如果你真的这么认为,那就错了!其实,它就是一个容器,用于存放线程的局部变量,我认为应该叫做 ThreadLocalVariable(线程局部变量)才对,真不理解为什么当初 ...
ThreadLocal是Java编程语言中的一个类,用于在多线程环境下提供线程局部变量。它为每个线程创建了一个独立的变量副本,每个线程只能访问自己的副本,不会影响其他线程。这种机制有助于实现线程安全,尤其在需要线程...
ThreadLocal的实现原理可以总结为:每个线程都有一个自己的ThreadLocalMap,用于存放线程的本地变量;ThreadLocal的set、get、remove方法都是基于ThreadLocalMap的操作。 ThreadLocal的优点是可以解决多线程访问...
在Java中,线程是程序的执行流,每个线程都有自己的程序计数器、虚拟机栈、本地方法栈和一部分堆内存。Java提供了两种创建线程的方式:继承Thread类和实现Runnable接口。实例中可能涵盖了这两种方式的使用,并通过...
10. **线程本地存储(ThreadLocal)**:为每个线程提供独立的变量副本,避免了线程间的共享数据冲突。 11. **并发集合**:如ConcurrentHashMap、CopyOnWriteArrayList等,这些集合类在并发环境下提供了高性能的读写...
ThreadLocal是Java中一个非常重要的类,它在多线程环境下经常使用,用于提供线程本地变量。这些变量使每个线程都有自己的一份拷贝,使得多个线程可以独立地使用变量,不会彼此影响。 ThreadLocal的使用场景非常广泛...
此外,Java提供了线程本地存储(ThreadLocal)机制,允许线程拥有自己的私有数据,这些数据只对线程本身可见,不受其他线程的影响。 #### Java线程:线程状态的转换 线程在其生命周期中会经历多种状态,包括新建(New...
除了上述提到的技术点,本教程还会涉及到ThreadLocal类、线程范围内共享变量、多个线程之间共享数据的方式、java5原子性操作类的应用、Callable与Future的应用、线程锁技术、读写锁技术等内容。这些技术点都旨在帮助...
`ThreadLocal`是Java平台提供的一种线程局部变量的解决方案,它为每一个使用该变量的线程都提供了独立的变量副本,使得每一个线程都可以独立地改变自己的副本,而不会影响其它线程所对应的副本。这不同于普通的静态...
线程本地存储(ThreadLocal)提供了线程内部的局部变量,这些变量对其他线程而言是隔离的。在多线程环境下,ThreadLocal可以用来存储线程特有对象,避免使用全局变量,从而提供线程安全。 线程阻塞是指线程在某些...
**线程局部变量(ThreadLocal)是Java编程中一个非常重要的概念,主要用于在多线程环境中为每个线程提供独立的变量副本。ThreadLocal不是一种数据结构,而是一种解决线程间共享数据的方式,它提供了线程安全的局部...
3. **缓存**:在线程内部需要快速访问的数据,可以使用ThreadLocal作为线程内的本地缓存,提高效率。 ### 实现原理 ThreadLocal 的核心在于每个线程内部的 `ThreadLocalMap`,这是一个定制化的哈希表,它存储了...
Java多线程是Java编程中不可或缺的部分,尤其在面试中,多线程相关的知识点往往成为高级工程师考察的重点。本文将详细解析几个常见的Java多线程面试问题及其答案。 1. **Java中的多线程同步是什么?** 多线程同步...
ThreadLocal是Java中的一个非常重要的线程安全工具类,它在多线程编程中扮演着独特的角色。通过创建ThreadLocal实例,我们可以为每个线程提供一个独立的变量副本,这些副本在各个线程之间互不影响,从而实现线程局部...
线程是程序的执行单元,每个线程都有自己的程序计数器、虚拟机栈、本地方法栈,而共享堆内存和方法区。线程允许一个应用程序同时执行多个任务,而进程则是资源分配的基本单位,每个进程都有独立的内存空间。 线程...
ThreadLocal,全称为`java.lang.ThreadLocal`,是Java中用于处理线程局部变量的一个类。它的设计目标是为每个线程提供一个独立的变量副本,使得这些副本只对当前线程可见,从而实现了线程之间的数据隔离。...
ThreadLocal 是 Java 中的一种线程本地存储机制,它提供了一种将数据绑定到线程的机制。ThreadLocal 可以用来实现线程安全的数据共享机制。 7. 程序、进程、线程的区别是什么?举个现实的例子说明 程序、进程、...