关于.net缓存问题

昨天测试人员反馈回来一个bug,通过缓存读取的数据,每次返回的数据条数都不一样。

调试了这个bug,发现只要使用了asp.net内置的缓存对象System.Web.Cache,或者企业库的缓存模块做的缓存,都会出现这个问题,但是如果是将缓存配置成memcached,则没有这个bug(系统支持多种缓存策略),刚开始以为是由于放入缓存的对象太大,超过了System.Web.Cache允许的大小,但是查了MSDN,google也发现有这个限制,做一个测试,将一个超级大的对象放入缓存,然后又取出来,程序正常,说明不是这个问题造成的,排除。由于放入缓存的对象是个LIST<T>集合,所以怀疑System.Web.Cache不支持,但是LIST<T>都是继承Object的,应该也不是这个问题,又排除。那到底是什么原因造成的,一条条的语句跟踪下来,在程序的最后一个函数中,有一个过滤函数,是根据不同的条件,对LIST<T>集合进行过滤删除,看来问题是出在这边了,System.Web.Cache取出来的对象在这边被更改了,因为这边没有做对象克隆,所以删除操作对象也就是缓存中的对象,由于memcached的缓存对象是保持到远程,因此更改这边的对象,并不会造成保存在memcached的对象被更改。所以会造成这个bug

posted @ 2010-06-09 11:46  阿sam  阅读(424)  评论(0编辑  收藏  举报