小问题,大隐患 ——ASP的对象释放

初步接触ASP的程序,对于对象的使用还不是很清楚,发生了一些问题,在别人的帮助下得到了纠正,在此想作为一个忠告写出来,防止自己以后再出同样的错误。如果有不对之处还希望大家多多指正。

对于ASP程序,有以下几个基本的内置对象:
Application对象,Request对象,Response对象,Server对象,Session对象,
绝大多说的ASP的操作代码都是运用这些内置对象的方法。

除了以上几个内置对象外,我们平常编写ASP的程序(涉及到数据库)都还需要用到以下几种新创建的对象:
1、数据库连接对象
    一般把这种对象叫CONNECTION
  创建方法
dim ProConn
set ProConn=Server.CreateObject("ADODB.CONNECTION")
  使用这个CONNECTION对象打开一个Access数据库
ProConn.Open "driver={Microsoft Access Driver (*.mdb)};uid=;pwd=;DBQ=" & Server.MapPath("DB.mdb")

2、Recordset对象
    这种对象主要用来在ASP代码中执行数据库查询的SQL语句
  创建方法
dim rs
Set rs=Server.CreateObject("ADODB.Recordset")
rs.Open strSQL,ProConn,1,1
'strSQL是SQL语句的字符串
'ProConn是CONNECTION对象
'1,1是游标参数

以上两种对象是我们经常碰到的,它们在使用完毕后必须注意的就是释放这些对象。

释放的方法如下:
ProConn.close
rs.close     
set ProConn=nothing   
set rs=nothing    

接下来要说的是引用自创的DLL时使用的对象,关于怎么封装ASP代码为DLL请参看上一篇文章.


这种对象的使用如下:
Dim ConDB
set ConDB=Server.CreateObject("ConDBDLL.Conn")
'调用ConDB的方法
ConDB.ConnectDB()
ConDB.DBPath()
'ConnectDB()和DBPath()都是这个封装DLL中自定义的方法

CreateObject("ConDBDLL.Conn")中的ConDBDLL是这个DLL的工程名,Conn是这个工程中的class
简单的一句set ConDB=Server.CreateObject("ConDBDLL.Conn")就使ConDB变成了一个自创对象。

就是这么简单的一个对象,我却忘记了在调用创建这个对象的ASP文件的其他ASP源代码文件中释放掉,致使为以后存在了巨大的隐患。

这样没有释放的对象,在这个ASP的网站多次使用后,系统就会变得其慢无比,原因都是因为没有释放这个对象。
都是自己不细心的结果。
哎………

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值