HttpRuntime.Cache.Add(
KeyName,//缓存名
KeyValue,//要缓存的对象
Dependencies,//依赖项
AbsoluteExpiration,//绝对过期时间
SlidingExpiration,//相对过期时间
Priority,//优先级
CacheItemRemovedCallback//缓存过期引发事件
);
示例:
HttpRuntime.Cache.Add(“CurrencyFundCodeCache”, docs, null, DateTime.Now.AddMinutes(2), Cache.NoSlidingExpiration, CacheItemPriority.Normal, null);
HttpRuntime.Cache.insert 参数同HttpRuntime.Cache.insert.add
详细说明
1、HttpRuntime.Cache 相当于就是一个缓存具体实现类,这个类虽然被放在了 System.Web 命名空间下了。但是非 Web 应用也是可以拿来用的。
2、HttpContext.Cache 是对上述缓存类的封装,由于封装到了 HttpContext ,局限于只能在知道 HttpContext 下使用,即只能用于 Web 应用。
综上所属,在可以的条件,尽量用 HttpRuntime.Cache ,而不是用 HttpContext.Cache 。
有以下几条缓存数据的规则。
第一,数据可能会被频繁的被使用,这种数据可以缓存。 第二,数据的访问频率非常高,或者一个数据的访问频率不高,但是它的生存周期很长,这样的数据最好也缓存起来。 第三是一个常常被忽略的问题,有时候我们缓存了太多数据,通常在一台X86的机子上,如果你要缓存的数据超过800M的话,就会出现内存溢出的错误。所以说缓存是有限的。换名话说,你应该估计缓存集的大小,把缓存集的大小限制在10以内,否则它可能会出问题。在Asp.net中,如果缓存过大的话也会报内存溢出错误,特别是如果缓存大的DataSet对象的时候。
你应该认真分析你的程序。根据实际情况来看哪里该用,哪里不该用。如:cache用得过多也会增大服务器的压力。整页输出缓存,又会影响数据的更新。 如果真的需要缓存很大量的数据,可以考虑静态技术。
详细应用:
/// <summary>
/// 获取缓存数据List
/// </summary>
/// <param name="key"></param>
/// <returns></returns>
public static List<string> TryGetCacheByKey(string key)
{
if (HttpRuntime.Cache[key] != null)
return (List<string>)HttpRuntime.Cache[key];
else return new List<string>();
}
/// <summary>
/// 建立缓存
/// </summary>
public static object TryAddCache(string key, object value)
{
if (HttpRuntime.Cache[key] == null && value != null)
return HttpRuntime.Cache.Add(key, value, null, System.Web.Caching.Cache.NoAbsoluteExpiration,
TimeSpan.FromMinutes(20), System.Web.Caching.CacheItemPriority.Normal, null);
else
return null;
}
/// <summary>
/// 移除缓存
/// </summary>
public static object TryRemoveCache(string key)
{
if (HttpRuntime.Cache[key] != null)
return HttpRuntime.Cache.Remove(key);
else
return null;
}
/// <summary>
/// 移除键中带某关键字的缓存
/// </summary>
public static void RemoveMultiCache(string keyInclude)
{
//IDictionaryEnumerator CacheEnum = HttpRuntime.Cache.GetEnumerator();
if (HttpRuntime.Cache.Get(keyInclude) != null)
HttpRuntime.Cache.Remove(keyInclude);
//while (CacheEnum.MoveNext())
//{
// if (CacheEnum.Key.ToString().Contains(keyInclude))
// HttpRuntime.Cache.Remove(CacheEnum.Key.ToString());
//}
}