锁池。。。

线程同步的方法有两种。
一是对方法加上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);
   }



以上只是代码设计,实际还没有开始编码测试。不知有无问题。
因为userId会不断增加,那么缓存的数据也会不断增加,这样可能会导致内存泄露。
可以定时清理一下。

你可能感兴趣的:(锁)