自己总结线程并发的访问资源的解决方法

1,信号量(Semaphore)

http://baike.baidu.com/view/1303265.htm

http://hxraid.iteye.com/blog/739265

http://uule.iteye.com/blog/1539813

2,java synchronized

http://www.cnblogs.com/devinzhang/archive/2011/12/14/2287675.html

3,threadlocal变量

http://www.iteye.com/topic/103804

对threadlocal的认识,threadlocal是解决线程并发访问资源问题的。他是给每一个线程都拷贝一个副本,互补影响,保证了每个线程只操作自己的
变量。和同步类似。一种场景:看看几天跳转处理是不是同一个线程的操作。可以设置一个变量由threadlocal管理。思路:设置一个静态的
threadlocal。设置一个静态的set和get.然后如果一个线程里面设置了变量数据,其他线程中任意时候如果取出来的数据是和set值一样的,就说明
是一个线程的。

定义一个threadlocal变量

public class RequestData{

private static ThreadLocal<IRequestMap> requestLocal = new ThreadLocal<IRequestMap>();
 
 //private IRequestMap map;

 public static IRequestMap getMap() {
  
  
  return requestLocal.get();
  
 }

 public static void setMap(IRequestMap map) {
  
  requestLocal.set(map);
 }


}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值