首页 > ehcache存入的和取出来的不同,求解。

ehcache存入的和取出来的不同,求解。

下面的代码是数据层的,代码意思是,从缓存中获得用户的设置信息,如果没有就去数据库查询,并且放入缓存中。

public CoreMap queryOptions(String name, String userId) throws Exception {
    CoreMap out = (CoreMap) CacheManager.get("SysOptions", "user_id_" + userId);//活动缓存
    List<Object> list = new ArrayList<Object>();
    if(out == null){
        //.......
        List<CoreMap> result = DBHepler.queryList(sql, params);
        out = optionsListToMap(result);
        CacheManager.set("SysOptions", "user_id_" + userId, (Serializable) out);//把out放入缓存
    }
    return out;
}

这里执行完之后,确实是把out变量的值放入了缓存。

但奇怪的地方是方法返回的时候,方法返回out,一层一层的返回到最初调用的地方。下次再取缓存值的时候就会出现多余的数据。。

貌似我也不好描述。。
简单点说,我缓存一个{name='', email='@gmail.com'},下次取出来就成了{name='', email='@gmail.com', url='http://sf.gg'},就是说会多出一些数据。

而这些多出的数据,是我最终要返回到页面上的数据。。

不知道这么说大家明白了没。。。

不知道是不是和值传递什么的相关,这个不太熟悉。
求解。。。


后续是不是给out的url变量赋值了?


评论里有点乱。整理下。
1.确保从DB中查询的出来的实例,不带有age,url属性;
2.实例放入缓存,手工从缓存中获取实例,看下情况;
3.如果上面正常。用上面的说的办法,看看能不能找到问题


这个可以debug跟踪下
1,确认下 第一次写入缓存的是否带url之类信息
2,如果1确认不带,那第二次读取的时候,是否是从缓存中读取的?

【热门文章】
【热门文章】