锁池。。。
线程同步的方法有两种。
一是对方法加上syncronized关键字,来表示这个方法是同步方法。
二是采用lock机制。
现实中遇到问题就是,一个类的某些方法需要同步,而且对于这个类的不同实例,都需要同步。所以在采用lock机制的时候,需要保证这个类的所有实例的lock都是同一个lock。
这样的话,lock对象就不能想平常那样采用定义类变量初始化来产生。必须采用某种机制来产生。
现实中遇到的问题再详细点就是说,对于某一个用户userId,这个类的某些方法需要同步。
即对于特定的userId,应该有唯一对应的lock对象来实现同步。
伪代码如下
class XXservice{
methodA(){
.......
.......
//需要同步的代码段。先要从一个syncronized的static方法中的静态变量lockMap中取得该user对应的lock
Lock Lock= Util.getUserLock(userId);
lock.lock();
try{
.......
}finally{lock.unlock}
}
}
其中util类中的同步方法定义为
public static syncronized Lock getUserLock(userId){
if(lockMap.containsKey(userId)){
return lockMap.get(userId);
}else{
Lock lock =new Lock();
lockMap.put(userId, lock);
return lockMap.get(userId);
}
}
以上只是代码设计,实际还没有开始编码测试。不知有无问题。