• ASP.NET的Cache缓存应用


    我们在页面上添加三个按钮并双击按钮创建事件处理方法,三个按钮使用不同的过期策略添加ASP.NET缓存。

    <asp:Button ID="btn_InsertNoExpirationCache" runat="server" Text="插入永不过期缓存"     
    OnClick="btn_InsertNoExpirationCache_Click" />  

     
    <asp:Button ID="btn_InsertAbsoluteExpirationCache" runat="server" Text="插入绝对时间    
    过期缓存" OnClick="btn_InsertAbsoluteExpirationCache_Click" />  

     
    <asp:Button ID="btn_InsertSlidingExpirationCache" runat="server" Text="插入变化时间    
    过期缓存" OnClick="btn_InsertSlidingExpirationCache_Click" />

    三个按钮的Click事件处理方法如下:

    protected void btn_InsertNoExpirationCache_Click(object sender, EventArgs e)   
    {   
        DataSet ds = GetData();   
        Cache.Insert("Data", ds);   
    }   
    protected void btn_InsertAbsoluteExpirationCache_Click(object sender, EventArgs e)   
    {   
        DataSet ds = GetData();   
        Cache.Insert("Data", ds,null, DateTime.Now.AddSeconds(10), TimeSpan.Zero);   
    }   
    protected void btn_InsertSlidingExpirationCache_Click(object sender, EventArgs e)   
    {   
        DataSet ds = GetData();   
        Cache.Insert("Data", ds, null, DateTime.MaxValue, TimeSpan.FromSeconds(10));   
    }

      我们来分析一下这三种ASP.NET缓存过期策略。

      ◆永不过期。直接赋值缓存的Key和Value即可

      ◆绝对时间过期。DateTime.Now.AddSeconds(10)表示缓存在10秒后过期,TimeSpan.Zero表示不使用平滑过期策略。

      ◆变化时间过期(平滑过期)。DateTime.MaxValue表示不使用绝对时间过期策略,TimeSpan.FromSeconds(10)表示缓存连续10秒没有访问就过期。

      在这里,我们都使用了Insert()方法来添加缓存。其实,Cache还有一个Add()方法也能向缓存中添加项。不同之处在于Add()方法只能添加缓存中没有的项,如果添加缓存中已有的项将失败(但不会抛出异常),而Insert()方法能覆盖原来的项。

      注意:和Application不同,这里不需要使用在插入ASP.NET缓存的时候进行锁操作,Cache会自己处理并发。

  • 相关阅读:
    Bozh 的技术博客 梦想成为Gnu/Linux | Unix后台架构师 | Read the fucking source code
    Welcome to the TANGO website
    repowatcher : about
    PyTango documentation — PyTango 8.0.2 documentation
    Visual Studio 2010旗舰版正式版序列号 civilman的专栏 博客频道 CSDN.NET
    BoostPro Binary Installer for Visual C++
    分享:httping 1.5.6 发布,HTTP 诊断工具
    浅析epoll – epoll函数深入讲解 C++爱好者博客
    分享:Jython动态加载Jar
    News BoostPro Computing BoostPro
  • 原文地址:https://www.cnblogs.com/kingfly/p/1629906.html
Copyright © 2020-2023  润新知