代码改变世界

关于动网迷城浪子(老迷)的缓存类的始末2

2008-06-22 13:10  废墟中的垃圾  阅读(490)  评论(0)    收藏  举报
这篇主要说一下老迷的vbs的缓存类的使用

Rem = 测试Demo
Rem
 = set Cache = new Caches
Rem
 = Cache.Reloadtime = 0.5
Rem
 = Cache.Name = "Demo"
Rem
 = if Cache.ObjIsEmpty then
Rem
 =     Cache.value = "52xx"
Rem
 =     response.Write("1")
Rem
 = else
Rem
 =     response.Write(Cache.value)
Rem
 = end if

这里要说明的就是,
Rem = set Cache = new Caches
Rem = Cache.Reloadtime = 0.5
Rem = Cache.Name = "Demo"
作为初始化的这两个赋值是必须的。

同时我将老迷的类扩展了一下,这样更加方便同志们的调试。
<script language="vbscript" runat="server">
Rem ==================使用说明==================== 
Rem
 = 本类模块是动网先锋原创,作者:迷城浪子。如采用本类模块,请不要去掉这个说明。这段注释不会影响执行的速度。 
Rem
 = 作用:缓存和缓存管理类 
Rem
 = 公有变量:Reloadtime 过期时间(单位为分钟)缺省值为14400 
Rem
 = MaxCount 缓存对象的最大值,超过则自动删除使用次数少的对象。缺省值为300 
Rem
 = CacheName 缓存组的总名称,缺省值为"Dvbbs",如果一个站点中有超过一个s缓存组,则需要外部改变这个值。 
Rem
 = 属性:Name 定义缓存对象名称,只写属性。 
Rem
 = 属性:value 读取和写入缓存数据。 
Rem
 = 函数:ObjIsEmpty()判断当前缓存是否过期。 
Rem
 = 方法:DelCahe(MyCaheName)手工删除一个缓存对象,参数是缓存对象的名称。 
Rem
 = 测试Demo
Rem
 = set Cache = new Caches
Rem
 = Cache.Reloadtime = 0.5
Rem
 = Cache.Name = "Demo"
Rem
 = if Cache.ObjIsEmpty then
Rem
 =     Cache.value = "52xx"
Rem
 =     response.Write("1")
Rem
 = else
Rem
 =     response.Write(Cache.value)
Rem
 = end if
Rem
 ======================== 

Class Caches 

Public Reloadtime,MaxCount,CacheName 
Private LocalCacheName,CacheData,DelCount 
Private Sub Class_Initialize() 
Reloadtime
=14400 
CacheName
="Dvbbs" 
End Sub

Private Sub SetCache(SetName,NewValue) 
    Application.Lock 
    Application(SetName) 
= NewValue 
    Application.unLock 
End Sub 

Private Sub makeEmpty(SetName) 
    Application.Lock 
    Application(SetName) 
= Empty 
    Application.unLock 
End Sub 

Public Property Let Name(ByVal vNewValue) 
    LocalCacheName
=LCase(vNewValue) 
End Property 

Public Property Let Value(ByVal vNewValue) 
    
If LocalCacheName<>"" Then 
        CacheData
=Application(CacheName&"_"&LocalCacheName) 
    
If IsArray(CacheData) Then 
        CacheData(
0)=vNewValue 
        CacheData(
1)=Now() 
    
Else 
        
ReDim CacheData(2
        CacheData(
0)=vNewValue 
        CacheData(
1)=Now() 
    
End If 
        SetCache CacheName
&"_"&LocalCacheName,CacheData 
    
Else 
        Err.Raise vbObjectError 
+ 1"DvbbsCacheServer"" please change the CacheName." 
    
End If 
End Property 

Public Property Get Value() 
    
If LocalCacheName<>"" Then 
        CacheData
=Application(CacheName&"_"&LocalCacheName) 
        
If IsArray(CacheData) Then 
            Value
=CacheData(0
        
Else 
            Err.Raise vbObjectError 
+ 1"DvbbsCacheServer"" The CacheData Is Empty." 
        
End If 
    
Else s
        Err.Raise vbObjectError 
+ 1"DvbbsCacheServer"" please change the CacheName." 
    
End If 
End Property

rem = 可以调用Application的过期时间,方便大家调试。
Public Property Get Expire() 
    
If LocalCacheName<>"" Then 
        CacheData
=Application(CacheName&"_"&LocalCacheName) 
        
If IsArray(CacheData) Then 
            Expire
=CacheData(1
        
Else 
            Err.Raise vbObjectError 
+ 1"DvbbsCacheServer"" The CacheData Is Empty." 
        
End If 
    
Else
        Err.Raise vbObjectError 
+ 1"DvbbsCacheServer"" please change the CacheName." 
    
End If 
End Property

Public Function ObjIsEmpty() 
    ObjIsEmpty
=True 
    CacheData
=Application(CacheName&"_"&LocalCacheName) 
    
If Not IsArray(CacheData) Then Exit Function 
    
If Not IsDate(CacheData(1)) Then Exit Function 
    
If DateDiff("s",CDate(CacheData(1)),Now()) < 60*Reloadtime Then 
        ObjIsEmpty
=False 
    
End If 
End Function 

Public Sub DelCahe(MyCaheName) 
    makeEmpty(CacheName
&"_"&MyCaheName) 
End Sub 

rem = 这里是增加的完全清楚缓存的方法。
Public Sub ClearAll()
    Application.Lock()
    Application.Contents.RemoveAll()
    Application.UnLock()
end sub

End Class 
</SCRIPT>

对于整体的缓存管理,会在以后的日子里面继续讨论和发问,希望更多的人可以给点建议。