安大互联
财经热点 > Asp编程 > scripting.dictionary的彻底研究
scripting.dictionary的彻底研究
浏览次数:【767】  发布日期:2009-8-13 12:09:22    文章分类:Asp编程   
专题:】 【
 

  关于script的dictionary对象,其实我想一开始ms是借鉴了python之类的动态脚本语言的,而且是面对客户端开发的关于这一点可以参考wrox的asp程序员参考手册里第137页里,如果在session级保存一个dictionary对象会降低全面的性能,而在application级保存一个dictionary对象会造成web服务器溃散,关于这个就不在多说了。

  目前我们要研究的是dictionary对象在单页的时候,有哪些设计时的缺陷:

  大伙可以这么试试

set rs=server.createobject("adodb.recordset")

sql="select * from table"

rs.open sql,conn,1,3

set ttt=server.createobject("scripting.dictionary")

ttt.add "xxx",rs("field")

set rs=nothing

liu=ttt("xxx")

  当你这么做的时候会发现一件啥事呢?asp页会告诉你发生意外!!!这个就很令人惊讶了,啥是意外呢?很难说,后来经过我反复的测试发现是因为不能把rs("field")的值直接给dictionary对象,经过反复研究得出的定论是如下的:dictionry是把rs("field")的内存地址给贮存了,这样的话,我刚才写的那个无疑是一种灾难,解决方法是把这个rs("field")放到一个变量里就可以解决了,可是dictionary对象难道不可以保存一个被nothing过的对象么?这个就是一个很大的疑惑了,所以我又写了这么一段程序,大伙可以保存成try.htm瞧瞧效果的

<script language='vbscript'>
set ttt=createobject("scripting.dictionary")
ttt.add "liu","uuu"
set ddd=createobject("scripting.dictionary")
ddd.add "ppp",ttt
set ttt=nothing
bbb=ddd("ppp")("liu")
alert(bbb)
</script>

  结果是啥?你会发现一段alert了uuu说明是没啥问题的,这就说明dictionary对象实际上就是把另外一个dictionary对象整个clone进来了,这就更验证了wrox的书中写的,dictionary对象在ms开发的时候实际上就是针对客户端的,这种说法了

  还有对数组与dictionary合用的代码也可以给大伙瞧瞧的

<script language='vbscript'>
i=1
picname=("xxx")
str="set " & "pic_" & i & "=createobject(" & """" & "scripting.dictionary" & """" & ")"
execute(str)
str="pic_" & i & ".add " & """" & "picname" & """" & "," & """" & picname & """"
execute(str)
dim ttt()
redim ttt(5)
ttt(0)="uuu"
pic_1.add "item",ttt
liu=pic_1("picname")

set pic_2=createobject("scripting.dictionary")
erase ttt
redim ttt(5)
ttt(0)="iii"
nnn=pic_1("item")(0)
pic_2.add "rrr",ttt
zzz=pic_2("rrr")(0)
alert(liu)
alert(nnn)
alert(zzz)
</script>

手机扫码浏览该文章
 ● 相关资讯专题
  • 网络建设业务咨询

   TEl:13626712526