- 浏览: 349410 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (176)
- Lucene (7)
- Solr (16)
- Hadoop/hbase (10)
- Nutch (2)
- 收藏链接 (7)
- javascript-xml-ajax (6)
- clasification (1)
- java base (22)
- TokenAnalyse (1)
- regEX (2)
- 持久化 (6)
- Linux (25)
- C/C++ (9)
- httpclient (5)
- TOMCAT (4)
- ECLIPSE (2)
- Parser_html (15)
- Database (2)
- struts2-spring-hibernate (7)
- finance (1)
- SEO (1)
- PHP (12)
- win2003 (5)
- security (3)
最新评论
-
menghuannvxia:
您好,我通过java上传文件到hadoop速度特别慢,怎么回事 ...
hadoop hdfs 一些用法 -
ydsakyclguozi:
ydsakyclguozi 写道david.org 写道错了. ...
hadoop修改默认的心跳检测的时间 -
ydsakyclguozi:
david.org 写道错了. heartbeat.reche ...
hadoop修改默认的心跳检测的时间 -
mypotatolove:
我现在想做用HttpClient从微博中爬取微博动态,能不能跟 ...
httpclient 设置user-agent -
青春的、脚步:
再者请教:如果查询的字段没有在配置文件的字段中加 termVe ...
solr morelikethis功能
package com.sodao.lucene; import java.util.Random; public class ThreadLocalTest implements Runnable{ ThreadLocal<Studen> studenThreadLocal = new ThreadLocal<Studen>(); @Override public void run() { String currentThreadName = Thread.currentThread().getName(); System.out.println(currentThreadName + " is running..."); Random random = new Random(); int age = random.nextInt(100); System.out.println(currentThreadName + " is set age: " + age); Studen studen = getStudent(); //通过这个方法,为每个线程都独立的new一个student对象,每个线程的的student对象都可以设置不同的值 studen.setAge(age); System.out.println(currentThreadName + " is first get age: " + studen.getAge()); try { Thread.sleep(500); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println( currentThreadName + " is second get age: " + studen.getAge()); } private Studen getStudent() { Studen studen = studenThreadLocal.get(); if (null == studen) { studen = new Studen(); studenThreadLocal.set(studen); } return studen; } public static void main(String[] args) { ThreadLocalTest t = new ThreadLocalTest(); Thread t1 = new Thread(t,"Thread A"); Thread t2 = new Thread(t,"Thread B"); t1.start(); t2.start(); } } class Studen{ int age; public int getAge() { return age; } public void setAge(int age) { this.age = age; } }
-------------------------------------
package com.sodao.lucene; import java.util.Random; public class MultiThreadTest implements Runnable{ Studen studen = new Studen(); @Override public void run() { String currentThreadName = Thread.currentThread().getName(); System.out.println(currentThreadName + " is running ...."); //同步 synchronized (studen) { Random random = new Random(); int age = random.nextInt(100); studen.setAge(age); System.out.println(currentThreadName + " is set age: " + age); System.out.println(currentThreadName + "is first get age: " + studen.getAge() ); try { Thread.sleep(500); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println(currentThreadName + " is second get age: " + studen.getAge() ); } } public static void main(String[] args) { MultiThreadTest m = new MultiThreadTest(); Thread t1 = new Thread(m,"Thread A"); Thread t2 = new Thread(m,"Thread B"); t1.start(); t2.start(); } } class Student { int age; public int getAge() { return age; } public void setAge(int age) { this.age = age; } }
以上2中方法都实现的功能相同,但方法不一样
ThreadLocal使用场合主要解决多线程中数据数据因并发产生不一致问题。ThreadLocal为每个线程的中并发访问的数据提供一个副本,通过访问副本来运行业务,这样的结果是耗费了内存,单大大减少了线程同步所带来性能消耗,也减少了线程并发控制的复杂度。
ThreadLocal不能使用原子类型,只能使用Object类型。ThreadLocal的使用比synchronized要简单得多。
ThreadLocal和Synchonized都用于解决多线程并发访问。但是ThreadLocal与synchronized有本质的区别。synchronized是利用锁的机制,使变量或代码块在某一时该只能被一个线程访问。而ThreadLocal为每一个线程都提供了变量的副本,使得每个线程在某一时间访问到的并不是同一个对象,这样就隔离了多个线程对数据的数据共享。而Synchronized却正好相反,它用于在多个线程间通信时能够获得数据共享。
Synchronized用于线程间的数据共享,而ThreadLocal则用于线程间的数据隔离。
当然ThreadLocal并不能替代synchronized,它们处理不同的问题域。Synchronized用于实现同步机制,比ThreadLocal更加复杂。
ThreadLocal使用的一般步骤
1、在多线程的类(如ThreadDemo类)中,创建一个ThreadLocal对象threadXxx,用来保存线程间需要隔离处理的对象xxx。
2、在ThreadDemo类中,创建一个获取要隔离访问的数据的方法getXxx(),在方法中判断,若ThreadLocal对象为null时候,应该new()一个隔离访问类型的对象,并强制转换为要应用的类型。
3、在ThreadDemo类的run()方法中,通过getXxx()方法获取要操作的数据,这样可以保证每个线程对应一个数据对象,在任何时刻都操作的是这个对象。
发表评论
-
从本地读取图片保存为byte[]
2009-10-21 16:02 1574public void read(){ String ... -
myeclipse里面配置xml文件提示方法
2009-09-29 23:02 8841. 在windows-preferences里面,在 ... -
freemarker
2009-09-08 16:52 1558public class FreeMarkerFactor ... -
资源文件加载的的类
2009-09-03 09:18 900public class ReadProperties { ... -
在MyEclipse中直接查看javaApi
2009-02-28 11:50 1970java每个版本的发布都会伴随发布一个 html ja ... -
GzipOutputStream及GzipInputStream的用法
2009-02-21 23:49 7339ByteArrayOutputStream array ... -
log4j 配制文件
2009-02-21 22:36 866#log4j中有五级logger #FATAL 0 #ER ... -
java 多线程问题
2009-02-04 19:22 879import java.util.ArrayList; im ... -
pr值的获取
2009-02-02 21:08 1059package com.sodao; /// < ... -
一句话设计模式
2009-01-10 23:32 100023种设计模式 - Pattern. 创建型 Abst ... -
编写java高效率代码注意事项
2009-01-09 14:41 15901.少用异常,多用判断。 2.将类的属性按种类分块,将方法的实 ... -
Eclipse中设置在创建新类时自动生成注释
2009-01-09 14:06 1482Eclipse中设置在创建新类时自动生成注释 windows- ... -
高质量JAVA代码编写规范
2009-01-09 09:48 23071. Java 命名约定 除 ... -
heritrix1.4.2安装
2009-01-06 16:07 13191、下载heritrix-1.14.2-src. ... -
MyEclipse/Eclipse的内存优化与内存不足的解决办法
2009-01-04 09:47 2856MyEclipse/Eclipse的内存优化与内存不足的解决办 ... -
Java编程经验汇总2(转载)
2008-12-09 21:03 1210笔者之前说的都是Struts- ... -
Java编程经验汇总1(绝对好文,转载)
2008-12-09 20:59 1611Java编程经验汇总 绝对 ... -
java RMI program
2008-12-09 13:04 827应用的是朋友的代码: package com.cmsz.c ... -
java tips and tricks
2008-12-08 15:54 816一、-Xmx512m 二、eclipse的插件的links安 ... -
Java Socket UDP Program
2008-12-07 23:09 2906import java.net.DatagramPacke ...
相关推荐
ThreadLocal 用法详解.md
主要介绍了Java ThreadLocal用法,结合实例形式详细分析了ThreadLocal线程局部变量相关原理、定义与使用方法,需要的朋友可以参考下
主要介绍了java 中ThreadLocal 的正确用法的相关资料,需要的朋友可以参考下
虽然所有的线程都能访问到这个ThreadLocal实例,但是每个线程却只能访问到自己通过调用ThreadLocal的set()方法设置的值。即使是两个不同的线程在同一个ThreadLocal对象上设置了不同的值,他们仍然无法访问到对方的值...
主要介绍了Android 中 ThreadLocal使用示例的相关资料,这里提供示例代码帮助大家学习理解这部分内容,需要的朋友可以参考下
在我们日常 Web 开发中难免遇到需要把一个参数层层的传递到最内层,然后中间层根本不需要使用这个参数,或者是仅仅在特定的工具类中使用,这样我们完全没有必要在每一个方法里面都传递这样一个 通用的参数。...
主要介绍了关于ThreadLocal对request和response的用法说明,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
早在 JDK 1.2 的时代,java.lang.ThreadLocal 就诞生了,它是为了解决多线程并发问题而设计的,只不过设计得有些难用,所以至今没有得到广泛使用。其实它还是挺有用的,不相信的话,我们一起来看看这个例子吧。 一个...
主要介绍了JAVA开发常用类库UUID、Optional、ThreadLocal、TimerTask、Base64使用方法与实例详解,需要的朋友可以参考下
目录SimpleDateFormat诡异bug复现SimpleDateFormat诡异bug字符串日期转...方法时加锁使用ThreadLocalThreadLocal介绍ThreadLocal使用demoThreadLocal源码探索ThreadLocal注意事项使用ThreadLocal解决SimpleDateFormat...
主要介绍了Android 中ThreadLocal的深入理解的相关资料,希望通过本文能帮助到大家,让大家理解应用ThreadLocal,需要的朋友可以参考下
AopLogAopLog是基于SpringAop和ThreadLocal实现的一个对请求方法埋点记录与处理的日志工具包。设计目的和场景:使用Spring Aop拦截程序,基本上都是同一个小异,不想日后每个项目都柏林都写一份这样的Aop拦截处理...
主要介绍了Java ThreadLocal类应用,结合具体案例形式分析了java ThreadLocal类的功能、原理、用法及相关操作注意事项,需要的朋友可以参考下
蓝桥杯leetcode 仓库内容是学习Java时所用的...Thread创建、ThreadLocal用法、Deamon守护线程 CountDownLatch和CyclicBarrier区别 12. LanQiao 蓝桥杯的测试 13. LeetCode 在LeetCode刷的题 14. Test 一些偶尔的测试
ThreadLocal为解决多线程程序的并发问题提供了一种新的思路,ThreadLocal并不是一个Thread,而是Thread的局部变量,本文就来深入解析Java中ThreadLocal线程类的作用和用法.
最好与一些日志框架一起使用。 核心没有任何依赖关系,因此可以位于类加载器层次结构的顶部。 支持 Spring 框架和 Liferay。 用法: Watch watch = ThreadLocalProfiler . start(); ThreadLocalProfiler . ...
synchronized关键字不属于方法特征签名的一部分,所以可以在覆盖方法的时候加上去。...如果在一个类内部都是使用synchronized关键字定义了方法f(),g()。那么当使用这个类的实例调用f()时,就不能再调用g()方法。
希望把jdk常用包使用记录一下,并结合一些常规的工作场景进行探讨,便于以后当工具/模板库使用 synchronized 同步关键字 volatile 关键字 AQS 框架 ReentrantLock 可重入锁 ReentrantReadWriteLock 读写锁 ...
使用数据连结池jdbc连结private static final ThreadLocal<Connection> tl=new ThreadLocal();//泛型为值的类型