页面数据缓冲

6.2.1 基本概念 ASP.NET提供了一个相当出色的缓存引擎机制,它允许页面保存和索引HTTP请求所要求的各种各样的对象。ASP.NET的缓存对各个应用来说是私有的,是存储各种对象的存储器。缓存的生存周期取决于应用的生存周期,也就是说,当应用重新启动时,缓存实际上也已重建。缓存提供了一个简单的字典接口,以便于开发者能够轻而易举放置对象到缓存中,并在以后使用。最简单的情况下,放置一个对象到缓存中,就如同对字典增加一个条目。例如: Cache(“myKey”)=MyValue 即是把MyValue放入缓存中一个叫myKey的缓存对象中,当需要引用myKey值时,可以采用下面的使用方式: myValue1=Cache(“myKey”) if myValue1 <> Null then ‘非空时的动作 … end if

 asp.net提供了三种缓存替换的策略: 1.“腐烂搜索”(Scavenging)比较类似于“最近最少使用”替换原则,当内存变得比教紧张时,缓存机制会找出最不常用和最不重要的对象,把它从内存中移出,以减轻系统压力。为控制“腐烂搜索”的具体行为,编程者必须在插入缓存对象时,指明插入它的耗费和多少时间内它必须被存取一次才能继续留在缓存中,以供替换时进行决择。 2.“到期控制”(Expiration)编程者可以指定缓存对象的生存周期,这种指定的时间可以是绝对的也可以是相对的。例如绝对的时间(下午6:00到期),相对时间(该对象距最近一次存取它的时间满10分钟即到期)。当一个缓存对象到期后,它将从缓冲内存中移出,此时对该对象的索引将得到null值,除非又重新插入该对象。 3.“文件和键值依赖” 从外部文件或者是其他缓存键值是否改变,来决定本身键值是否有效。如果依赖发生改变,缓存对象将变得不可使用,并从缓存中移动出来。试想这样一种情况,应用从一个XML文件中读出金融信息,而该文件又被定期地修改。应用的作用是利用从该文件读出的信息构造一个图形对象以表示销售的情况。当应用读入文件时,它把数据插入缓存中,并记录下文件的依赖关系。当文件发生修改时,应用使开始产生的缓存对象无效并从内存中移出已经无用的数据,此后应用重新读入文件的数据,再把更新后的数据放入缓存,这样就完成了信息的更新,并返回给最终用户。 6.2.2 实例例子:从一个XML中读出用户信息并显示在页面上,页面提供了两个按钮,一个为增加用户,一个为刷新。我们在内存中建立了一个缓存对象“DataCache5”,它与客户信息文件”custom1.xml”建立了依赖关系。当custom1.xml文件未发生变化时,我们按下“刷新”按钮,可以看到信息是从缓存中读出的;当我们输入客户相应的资料,增加了一个客户以后,再按下“刷新“按钮后,我们可以看到客户信息变成了从文件读出。 1.ASPX源程序(performance/FormDataCache.aspx): <!-- 文件名:FormDataCache.aspx --> <%@ Import Namespace="System.IO" %> <%@ Import Namespace="System.Data" %> <html> <script language="VB" runat="server"> sub LoadData1 '当缓存对象DataCache5有效时,从缓存中读出客户信息;无效时,从文件读出信息 dim dv1 as DataView  dv1=Cache("DataCache5")  if dv1 = Nothing  dim ds as DataSet  dim fs as FileStream  dim sr as StreamReader

 ds=New DataSet  fs=New FileStream(Server.MapPath("custom1.xml"),FileMode.Open,FileAccess.Read)  sr=New StreamReader(fs)  ds.ReadXml(sr)  fs.Close()  dv1=new DataView(ds.Tables(0))  Cache.Insert("DataCache5",dv1,New cachedependency(Server.MapPath("custom1.xml")))  lblMsg.text="数据从文件中读出..."  Else  lblmsg.text="数据从缓存中读出..."  end if '绑定到DataGrid1对象  DataGrid1.datasource = dv1  DataGrid1.databind() end sub sub Page_Load(s as object,e as eventargs) '加载页面时,从文件中读出客户信息  if Not IsPostBack  LoadData1()  end if end sub sub AddBtn_Click(s as object,e as eventargs) '增加一个客户信息到文件中 dim FS as FileStream dim Reader as StreamReader dim DS as DataSet dim dr1 as DataRow dim tw1 as TextWriter  if Not Page.IsValid  lblMsg.text="还有域未曾填充..."  else  DS=New DataSet()  FS=New FileStream(Server.mappath("custom1.xml"),FileMode.Open,FileAccess.Read,FileShare.ReadWrite)  Reader=New StreamReader(FS)  DS.readxml(Reader)         FS.Close()  dr1=DS.tables(0).newrow()      dr1("CustName")=txtName.text  dr1("CustIdno")=txtIdno.text  dr1("CustCard")=txtCard.text  DS.tables(0).rows.add(dr1)               FS=New FileStream(Server.MapPath("custom1.xml"),FileMode.Create,FileAccess.ReadWrite,FileShare.ReadWrite)  tw1=New StreamWriter(FS)  tw1=textwriter.synchronized(tw1)  DS.writexml(tw1)  tw1.close()  LoadData1()  end if end sub sub RefreshBtn_Click(s as object,e as eventargs)  LoadData1() end sub </script> <head> <title> 数据缓冲实验 </title> </head> <body> <center> <form runat=server> <h2>XML文件缓存测试</h2> <ASP:DataGrid id="DataGrid1" runat="server"         Width="600"         BorderColor="black"         ShowFooter="false"         CellPadding=3         CellSpacing="0"         Font-Name="Verdana"         Font-Size="8pt"           /> <hr> <h3>添加一个客户信息</h3> <table> <tr> <td>姓    名:</td> <td><ASP:textbox id=txtName runat=server /></td> <td><ASP:RequiredFieldValidator ControlToValidate="txtName" Display="static" ErrorMessage="*" runat=server /> </td> </tr> <tr> <td>身份证号:</td> <td><ASP:textbox id=txtIdno runat=server /></td> <td><ASP:RequiredFieldValidator ControlToValidate="txtIdno" Display="static" ErrorMessage="*" runat=server /> </td> </tr> <tr> <td>信用卡号:</td> <td><ASP:textbox id=txtCard runat=server /></td> <td><ASP:RequiredFieldValidator ControlToValidate="txtCard" Display="static" ErrorMessage="*" runat=server /> </td> </tr> </table> <p> <asp:button text="增加" οnclick="AddBtn_Click" runat=server /> <asp:button text="刷新" οnclick="RefreshBtn_Click" runat=server /> <p><p><p> <asp:label id=lblMsg runat=server /> </form> </center> </body> </html>

### JSP 页面缓冲区的概念与作用 #### 缓冲区的概念 JSP页面中的缓冲区是一个临时存储区域,在处理请求并生成响应的过程中用于暂存输出的数据。当JSP页面执行时,所有的输出内容(HTML、动态生成的内容等)都会先写入缓冲区,而不是立即发送到客户端[^2]。 #### 缓冲区的作用 1. **优化性能** 缓冲区的存在允许服务器在完成整个页面的处理后再一次性将数据发送至客户端,从而减少网络传输次数,提高效率[^4]。 2. **支持修改和重定向** 如果在页面处理过程中需要进行跳转或其他操作(如`pageContext.forward()`),缓冲区可以暂时保存未发送的内容,直到确认最终的操作方向[^1]。 3. **错误恢复能力** 在某些情况下,如果发生异常或错误,可以通过清空缓冲区(如调用`response.reset()`)来重新构建响应内容,而无需完全重启整个流程。 4. **控制输出时机** 开发者可以根据需求通过编程方式管理缓冲区的行为,例如使用`response.flushBuffer()`强制立即将缓冲区内容发送给客户端,或者通过`response.setBufferSize(int size)`调整缓冲区大小以适应不同的应用场景。 #### 缓冲区的工作机制 - 输出内容默认会被写入缓冲区,只有当满足特定条件时才会实际发送到客户端: - 缓冲区已满; - 调用了`response.getWriter().flush()`或`out.flush()`方法; - 页面执行完毕且缓冲区内仍有待发送的数据。 - `response.getWriter()`和`out.write()`的区别在于,前者优先于后者向客户端发送数据。这意味着即使两者都存在输出,`response.getWriter()`的内容也会更早到达客户端。 ```java // 示例代码展示如何手动刷新缓冲区 <% out.println("这是第一个部分"); out.flush(); // 手动刷新缓冲区 response.getWriter().write("这是第二个部分"); %> ``` 上述代码片段展示了如何利用`out.flush()`提前将部分内容发送到客户端,同时也体现了`response.getWriter()`相对于`out.write()`的优先级差异。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值