虚拟主机行业最新资讯 虚拟主机评测对比 互联网最新动态 技术学院 站长资讯 在线教程 网站运营
搜索优化 服务器 网络编程 图形图象 站长之家 网页制作 操作系统
冲浪宝典 软件教学 视频通信 办公软件 邮件系统 网络安全 认证考试
您当前位置:站长资讯>-> 网站运营-> 网站运营
程序运行速度测试-ASP教程,脚本编码
作者:网友供稿 点击:28
  西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!虚拟主机可在线rar解压,自动数据恢复设置虚拟目录等.虚拟主机免费赠送访问统计,企业邮局.Cn域名注册10元/年,空间150元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金!
文章页数:[1] 
程序运行速度试验结果:
1。作相同的分支条件判断:if  比  select慢。
用以下程序测试:
<%
dim tttt1,ttt2
session("ii")=0
for sn=0 to 5
ttt1=now()
for i=0 to 300000
   if session("ii")=0 then
      session("ii")=1
   else
     if session("ii")=1 then
      session("ii")=2
     else
       if session("ii")=2 then
          session("ii")=3
        else
           session("ii")=0
         end if
     end if
   end if
next
ttt2=now()
tou=ttt2-ttt1
response.write sn&"、"&tou*24*60*60&"<br>"
next

for sn=0 to 5
ttt1=now()
for i=0 to 300000
   select case session("ii")
      case 0
         session("ii")=1
      case 1
         session("ii")=2
       case 2
         session("ii")=3
       case 3
         session("ii")=0
   end select
next
ttt2=now()
tou=ttt2-ttt1
response.write sn&"、"&tou*24*60*60&"<br>"
next

%>
2, 如果把上例中的session对象改为用普通的变量存。速度会快差不多8倍
3,进行字符串连接时往中间加入相同多的字符串,基数越大,越慢。
通过下面的程序测试:
<%
dim tttt1,ttt2
session("ii")=0
for sn=0 to 5
ttt1=now()
  txt=""
   for i=0 to 10000
       txt="a"&txt
   next
ttt2=now()
tou=ttt2-ttt1
response.write sn&"、"&tou*24*60*60&"<br>"
next
%>
进行同样长字节的字符连接时,汉字比英文快4倍,通过下面的程序测试
<%

dim tttt1,ttt2
for sn=0 to 5
ttt1=now()
  txt=""
   for i=0 to 20000
          txt="人"&txt
   next
ttt2=now()
tou=ttt2-ttt1
response.write sn&"、"&tou*24*60*60&"<br>"
next

txt=""
for sn=0 to 5
ttt1=now()
  txt=""
   for i=0 to 20000
          txt="aa"&txt
   next
ttt2=now()
tou=ttt2-ttt1
response.write sn&"、"&tou*24*60*60&"<br>"
next

%>
用for 循环比do  while循环要快得多,用下面的程序测试,虽然for循环中要多一个变量,
<%
dim tttt1,ttt2

for sn=0 to 5
ttt1=now()
  i=0
   do while i<=100000
      i=i+1
   loop
ttt2=now()
tou=ttt2-ttt1
response.write sn&"、"&tou*24*60*60&"<br>"
next

for sn=0 to 5
ttt1=now()
   ii=0
   for i=0 to 100000
    ii=ii+1
   next
ttt2=now()
tou=ttt2-ttt1
response.write sn&"、"&tou*24*60*60&"<br>"
next
%>
定义5000个一个字符的session并不比定义5000个有5000个字符串长的session少花很多时间,两者时间差仅为近一倍,用一秒多钟。倒是生成这个5000个字符长的变量花了不少的时间,<%
dim tttt1,ttt2
c="a"
for sn=0 to 5

session.abandon
ttt1=now()
   for i=0 to 5000
       session("s"&i)=c
    next
ttt2=now()
tou=ttt2-ttt1
response.write sn&"、"&tou*24*60*60&":"&session("s"&i-1)&"<br>"
next

for i=0 to 5000
  c="a"&c
next

for sn=0 to 5
session.abandon
ttt1=now()
   for i=0 to 5000
       session("s"&i)=c
    next
ttt2=now()
tou=ttt2-ttt1
response.write sn&"、"&tou*24*60*60&":"  &session("s"&i-1)&"<br>"
next


%>


这段程序从sn=3起就很慢,而前面非常快
<!--#include file="filetou.asp"-->
<%
dim tttt1,ttt2
for sn=0 to 5
ttt1=now()
  for i=1 to  20
   sql ="select 名称  from user where 名称=阿余"
   set rs=server.createobject("adodb.recordset")                        
   rs.open sql,conn,1,3
   rs("名称")="阿余"
   rs.update
   rs.close
next
ttt2=now()
tou=ttt2-ttt1
response.write sn&"、"&tou*24*60*60&":"&session("s"&i-1)&"<br>"
next


%>


而这样就快多了。看来建对象很要花些时间,还有,用move 0,1 和  movefirst 相比速度没有什么差别。
<!--#include file="filetou.asp"-->
<%
   sql ="select 名称  from user where 名称=阿余"
   set rs=server.createobject("adodb.recordset")                        
   rs.open sql,conn,1,3
dim tttt1,ttt2
for sn=0 to 5
ttt1=now()
  for i=1 to  700
   rs("名称")="阿余"
   rs.update
   rs.movefirst
next
ttt2=now()
tou=ttt2-ttt1
response.write sn&"、"&tou*24*60*60&":"&session("s"&i-1)&"<br>"
next
%>

而这两种方式相比,后者要慢3倍,可能是后者要重新查询,但比前面的用rs建查询后又去改,改了又关,相比,要快了不知多少。
<!--#include file="filetou.asp"-->
<%
   sql ="select 名称  from user where 名称=阿余"
   set rs=server.createobject("adodb.recordset")                        
   rs.open sql,conn,1,3
dim tttt1,ttt2

for sn=0 to 5
ttt1=now()
  for i=1 to  700
   rs("名称")="阿余"
   rs.update
   rs.movefirst
next
ttt2=now()
tou=ttt2-ttt1
response.write sn&"、"&tou*24*60*60&":"&session("s"&i-1)&"<br>"
next

for sn=0 to 5
ttt1=now()
  for i=1 to  700
     sql="update user set 名称=阿余  where 名称=阿余"
     conn.execute sql,0,-1
next
ttt2=now()
tou=ttt2-ttt1
response.write sn&"、"&tou*24*60*60&":"&session("s"&i-1)&"<br>"
next

%>


新加一万条记录谁快?第一种方法用31秒,后者直到超时仍未完成。不得已,少掉一个0,1000条是,后者慢一半。
<!--#include file="filetou.asp"-->
<%
   sql ="select 名称  from user where id=0"
   set rs=server.createobject("adodb.recordset")                        
   rs.open sql,conn,1,3
dim tttt1,ttt2

ttt1=now()
  for i=1 to  10000
   rs.addnew
   rs("名称")="阿余a"
   rs.update
next
ttt2=now()
tou=ttt2-ttt1
response.write sn&"、"&tou*24*60*60&":"&session("s"&i-1)&"<br>"


ttt1=now()
  for i=1 to  10000
     sql=" insert into  user (名称) values(阿余b)"
     conn.execute sql,0,-1
next
ttt2=now()
tou=ttt2-ttt1
response.write sn&"、"&tou*24*60*60&":"&session("s"&i-1)&"<br>"


%>

下面的程序结果说明rs新增记录较快,而删除较慢,用conn新增慢,但删除很快。
运行的结果为:
、3.00000007264316:
、7.99999998416752:
、1.99999983888119:
、0:
后来用rs新增记录5000条,并用conn删除这5000条, 结果为:
、17.000000202097:
、1.00000023376197:
程序为:
<!--#include file="filetou.asp"-->
<%
dim tttt1,ttt2
ttt1=now()
sql ="select 名称  from user where id=0"
   set rs=server.createobject("adodb.recordset")                        
   rs.open sql,conn,1,3
  for i=1 to  1000
   rs.addnew
   rs("名称")="阿余a"
   rs.update
next
ttt2=now()
tou=ttt2-ttt1
response.write sn&"、"&tou*24*60*60&":"&session("s"&i-1)&"<br>"


ttt1=now()
  for i=1 to  1000
     sql=" insert into  user (名称) values(阿余b)"
     conn.execute sql,0,-1
next
ttt2=now()
tou=ttt2-ttt1
response.write sn&"、"&tou*24*60*60&":"&session("s"&i-1)&"<br>"




ttt1=now()
   sql ="select  名称 from user where 名称=阿余a"
   set rs=server.createobject("adodb.recordset")                        
   rs.open sql,conn,1,3
do while not rs.eof
   rs.delete
   rs.update
   rs.move 0,1
  loop
ttt2=now()
tou=ttt2-ttt1
response.write sn&"、"&tou*24*60*60&":"&session("s"&i-1)&"<br>"


ttt1=now()
   sql ="delete from user  where 名称=阿余b"
    conn.execute sql,0,-1
ttt2=now()
tou=ttt2-ttt1
response.write sn&"、"&tou*24*60*60&":"&session("s"&i-1)&"<br>"


%>
文章整理:西部数码--专业提供域名注册虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!
文章页数:[1] 
相关主题
Google

热门文章
·ASP.NET的安装与运行环境-.NET教程,Asp.Net开发
·运用.NET+SQL Server2005构建多层网站(3)-.NET教程,数据库应用
·JAVA写的四则混合运算-JSP教程,Java技巧及代码
·获取高精度的时间差,可以用来分析页面运行时间的长短-.NET教程,Asp.Net开发
·基于.Net平台应用程序唯一运行实例C#代码实现-.NET教程,C#语言
·Alexa 世界网站排名研究(下)-网站运营,搜索引擎推广
·运用.NET+SQL Server2005构建多层网站(1)-.NET教程,数据库应用
·优化系统让Photoshop运行更流畅-网页设计,Photoshop
·ASP.NET 2.0运行时简要分析-.NET教程,Asp.Net开发
·手工打造运算符重载过程-.NET教程,C#语言

最新文章
·MySQL服务器内部安全数据目录访问
·MySQL和SQL Server,到底选择谁?
·五种推广模式的优劣的比较
·基于.Net平台应用程序唯一运行实例C#代码实现-.NET教程,C#语言
·运用反射给实体赋值-.NET教程,Asp.Net开发
·大数运算(一)-.NET教程,评论及其它
·虚拟主机上asp.net运行权限不足问题及解决-.NET教程,Asp.Net开发
·ASP.NET底层架构探索之进入.NET运行时-.NET教程,Asp.Net开发
·基于.Net平台应用程序唯一运行实例实现-.NET教程,.NET Framework
·ASP.NET 2.0运行时简要分析-.NET教程,Asp.Net开发

相关主题



友情链接
CNNIC 西部数码
万网 自助建站
虚拟主机 asp空间
域名注册 域名
域名申请 主页空间
论坛空间 网站空间
国际域名 虚拟空间
空间租用 DDOS防火墙
成都主机托管 四川主机托管
主机租用 服务器租用
网站目录 一班在线
虚拟主机 网址大全
软件下载
自助链接
虚拟主机资讯 特价虚拟主机


版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!

特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
  打印  刷新  关闭


联系我们  |  广告服务  |  免责声明  |  友情连接
Copyright ?2005 - 2006 All Rights Reserved
蜀ICP备05000045号