由于这几张表读取的非常频繁。于是便相对第一次查询的结果进行缓存。如果缓存中没有相应的数据再从数据库中读取。
现的问题,这个方法上要不要考滤同步的问题。
我是这样想的。当同一时刻有多个用户同时查询相同的数据时。此时要查询的数据刚好在缓存中没有。那么这时要从数据库中读取。
假设A查询时执行的到的代码为:List conInfoList = new ArrayList();
而B查询执行到代码为:if(pageConInfoMap.get(riskCode + comCode) != null)
那么现在的问题是A将结果查询出放入缓存。而B又一次将结果查询出放入缓存中。缓存用的是map不会产生重复记录的情况。
但是本来要查询一次数据库,其它的都要从缓存中读取。可是假设的情况却读了两次,在实际运行中,有可不只是两次。所以说我是否应当要取读数据进行缓存的方法设为同步呢。
代码如下:
已经将其设为同步的
public class PageAutoConfigServer { private static final Map pageConInfoMap = new HashMap(); public synchronized List getPageConfigInfo(String riskCode, String comCode) throws Exception { if(pageConInfoMap.get(riskCode + comCode) != null){ return (List)pageConInfoMap.get(riskCode + comCode); } DbPool dbPool = new DbPool(); List conInfoList = new ArrayList(); try { dbPool.open(SysConst.getProperty("DDCCDATASOURCE")); conInfoList = new DBPageFiledAutoConfig().getPageElementsConfigInfo(riskCode, comCode, dbPool); pageConInfoMap.put(riskCode + comCode, conInfoList); } catch (Exception e) { throw e; } finally{ dbPool.close(); } return conInfoList; } }
说明此方法是在jsp页面中直接调用的