首先,这是我在公司项目中遇到的情况,表述如果有问题的话,希望大家留言指出,不胜感激。
遇到的问题:
在做公司的项目对外接口时,其中有个加入会议的接口,该接口的流程是,首先根据报文查询会议(该站点下的正在进行)是否存在,若存在则直接返回会议对象,若不存在则新建一个会议后返回会议对象。
这样就导致一个问题,如果多人同时加入同一个会议,就可能出现每人新建一个会议的情况,那样这些人就不能进入同一个会议。所以这里需要同步一下,同步最小的代码片段,即查询会议与创建会议这里。每个用户就相当与每个线程,当这些线程调用
OuterServiceImpl
对象时,
lock
是静态变量,
OuterServiceImpl
所有对象共享
lock
,所以以该对象为锁,同步代码片段。每个线程执行到该同步代码块,都需要等待上个线程释放锁,如此就不会出现用户进入的不是同一个会议的情况了。 --2013.12.18
@Service
public class OuterServiceImpl extends BaseService implements OuterService {
/*
* 特殊的instance变量
* 注:零长度的byte数组对象创建起来将比任何对象都经济――查看编译后的字节码:
* 生成零长度的byte[]对象只需3条操作码,而Object lock = new Object()则需要7行操作码。
*/
private static byte[] lock = new byte[0];
@Override
public ConfBase joinConf(String xmlString) throws OuterConfException{
JoinConfOuter joinConfOuter = getJoinConfOuter(xmlString);
SiteBase site = siteService.getSiteBaseBySiteSign(joinConfOuter.getSiteSign());
// getErrorCode(site, joinConfOuter);
ConfBase conf = null;
synchronized(lock) {
conf = confOuterService.getOpeningConfByMtgkey(
joinConfOuter.getMtgKey(), site.getSiteSign()); //根据MtgKey与站点标识获取正在进行的会议信息
if(conf == null){
return confOuterService.createOuterConf(joinConfOuter, site);
}
}
return conf;
}