top
Loading...
15種asp使用技巧(中文版)

技巧1:給應用層文件使用GLOBAL.ASA
技巧2:從產品源代碼中移去HTML注釋
技巧3:多個Response.write聲明
技巧4:使用標志例示對象
技巧5:盡可能的使用本地(局部)變量
技巧6:避免多維數組
技巧7:避免公用(全局)變量
技巧8:使用文字路徑
技巧9:使用"Dictionary"對象
技巧10:充分利用瀏覽器的回退功能
技巧11:避免使用服務器端變量
技巧12:使用"option explicit"
技巧13:將采集到的值拷貝到本地(局部)變量當中
技巧14:謹慎使用session對象
技巧15:做性能測試

*技巧1:給應用層文件使用GLOBAL.ASA

將文件載入GLOBAL.ASA中的一個應用層數組中,而不是通過使用ASP文件系統對象在頁面上讀取文件。
GLOBAL.ASA可用于指定事件腳本,也可用于聲明擁有session或應用程序范圍的對象。它不直接顯示給用戶,而是存儲應用層事件的信息和對象。然后通過頁面就可以指向存有數據的應用層數組。這就意味著每有一個服務器端請求就讀一次文件,不是每個用戶每頁讀一次。你可以運行一個獨立的ASP文件去刷新應用層數組的內容,同時你也可以考慮使用dictionary對象(見技巧9)。
這個技巧可以大大加快你的系統速度。
那么將如何實現該技巧呢?
如果你是一個腳本編寫人員,必須使用文件系統對象讀取文件放入一個數組或一個dictionary對象中。然后在GLOBAL.ASA中讀取文件并且把數組(放有你讀取的文件內容)或dictionary對象放到應用層聲明中。這樣就可讓用戶在數組或dictionary對象中存取信息,而不必每次通過一個ASP請求去提交信息。
但也許你會想“如果緩存中的內容需要更新又該怎么辦呢?我敢打賭不會用到。”其實不然。如果緩存中的內容需要更新,你可以調用一個包含有可執行應用程序鎖定命令腳本的僅管理員可存取的ASP文件,在數組或dictionary對象中更新緩存信息,最后執行應用程序鎖定命令。

*技巧2:從產品源代碼中移去HTML注釋(IIS3.0適用)
不錯,難寫的肯定也難懂。開個玩笑,這不代表要你把所有的HTML注釋去掉(腳本注釋就挺好的),大范圍的HTML文本都能成批的拷貝到客戶端。這樣的話,你的腳本在IIS3.0上會運行得更快(在IIS4.0中,HTML注釋不再會導致執行速度的降低)。

*技巧3:多個Response.write聲明
如果你是在代碼中的好幾個地方用<%=...%>格式書寫輸出結果,那么考慮一下把這些結果合到一塊,用一個Response.write語句寫出來。然后你再看看你的HTML代碼和vbscript腳本的組成。不要把HTML和vbscript腳本散布得太開,盡量寫成成塊的HTML和vbscript腳本。

*技巧4:使用標志例示對象
如果你需要指向那些也許用不著的對象,那么就用標志例示,而不是用Server.createobject.用Server.createobject將立刻生成該對象,如果你以后都用不著它的話,就等于浪費資源。

*技巧5:盡可能的使用本地(局部)變量
(以下的新技巧將取代較早前發布的“在一行內定義變量”,其中包含有一些錯誤觀點):
局部變量是在子程序和函數中定義的(也就是常說局部范圍的變量),這些變量被編譯成數字指向并放入一張表中。這些局部變量的指向可以通過一次編譯完成。而全局變量則是在運行時被執行的。這就意味著局部變量的存取要比全局變量快好幾倍。而且,多維全局變量是其中最慢的,當第一次使用一個多維全局變量時,在新的對象產生之前,就要在整個對象模型中搜索一遍同名的對象。
以下是一個非常常見的例子:
Foo.bar.blah.baz = Foo.bar.blah.qaz(1)
If Foo.bar.blah.zaq = Foo.bar.blah.abc then
運行時產生如下結果:
1)變量Foo被定義為一個全局變量
2)變量bar被定義為Foo的一個成員
3)變量blah被定義為Foo.bar的一個成員
4)變量qaz被定義為Foo.bar.blah的一個成員
5)調用 Foo.bar.blah.quaz(1)
6)重復1至3。系統并不知道如果調用qaz改變了對象模型1-3步必須重新執行
7)定義baz為 Foo.bar.blah的成員,輸出值
8)重復1-3,執行zaq
9)重復1-3,執行abc
正如你看到的,效率極其低下,最快的方法就是把這些代碼寫在vbscript中:
Set myobj = Foo.bar.blah ' do the resolution of blah ONCE
Myobj.baz = myobj.qaz(1)
If Myobj.zaq = Myobj.abc then

*技巧6:避免重復定義數組
當我們在使用dim時,避免重新定義數組。因為你可能要用redim去重新定義數組的大小。至于要做這樣的操作的話,如果你的機器內存不是很大,那么最好在一開始就考慮到最壞的打算去設置數組的長度或者設置最佳狀態時的長度,在非常必要時才使用redim。當然這樣并不意味著要去增加內存,如果你不是很需要的話。
以下舉例說明不恰當的使用redim
<%
dim MyArray()
Redim MyArrray(2)
MyArray(0) = "hello"
MyArray(1) = "good-bye"
.
.
.
some other code where you end up needing
more space happens then ...
Redim Preserve MyArray(5)
MyArray(2) = "more stuff"
MyArray(3) = "even more stuff"
MyArray(4) = "yet more stuff"
%>
其實在開始就定義myarray(5),而以后需要的話再用redim去增加他的大小,這樣的話可能會占用一些內存,但速度就要快得多了。

*技巧7:避免公用(全局)變量
不要使用用public定義的變量。如果你是寫vbscript或在ActiveX控件或java applet中存取變量,那么盡可能避免公用變量。public關鍵字通常是為以后使用設計的,既然public不能給你帶來什么好處,那最好還是用dim吧。



*技巧8:使用絕對路徑
如果可能的話盡量避免使用相對路徑,而使用絕對路徑。使用相對路徑將需要IIS返回當前服務器路徑,這就意味著對IIS的特殊請求造成執行速度低下。
注:慢點就慢點唄,使用相對路徑移植什么的都方便得多呀。

*技巧9:使用"Dictionary"對象

VBScript中提供的dictionary對象可提供快速查找和任意帶關鍵字數據的存儲。通過dictionary對象可以根據關鍵字存取數組中的各項數據,這樣就能更快地找到在內存中不連續的內容(因為你是指定你正在使用的關鍵字,而不是要知道對象在數組中存放的位置)。如果你要查找的是非線性的關鍵字數據,使用dictionary對象就要快得多了。
然而,如果關鍵字數據在內存中是連續的,那么數組在查找、存儲數據起來將更快。同時也需要注意的是在dictionary中建立索引要比在數組中慢。你應該選擇對你來說效果最好的數據結構。


*技巧10:充分利用瀏覽器的回退功能
如果你使用的是個smart的瀏覽器,那么他會幫你做很多的回退工作,只要用得著,不妨多用用。那么,通過你的腳本執行回退,當有任何錯誤發生時你可以回到前面去,并從后訪問數據庫。但要記住的是,當你訪問服務器上存在的數據庫時就要執行一次對數據庫的操作。如果你要返回的那個表單有很多變量的話,那就有點劃不來了。如果你確實知道你需要在客戶端執行很多代碼,那么為了加快執行速度把代碼移到客戶端。當你在客戶端運行時,處理器就歸你了,服務器呢,只好用他自身的處理能力去處理他所接到的請求。
還有個好辦法,如果你使用的表單中用了很多服務器端的腳本并且有不少條件輸入,那么最好把這些觸發反應的代碼放到客戶端腳本引擎中去(比如vbscript,javascript)。忽略這些,服務器代碼運行得就快了,因為對于那些不是很必要的代碼就不送到服務器端執行了。當然這僅對那些比較小的代碼適用,至于大的嘛,就不太合適了。

*技巧11:避免使用服務器端變量
通過服務器端變量進行訪問數據時,就需要web向服務器提出請求,然后收集所有的服務器端變量,而不僅僅只是你請求的那個變量。這就類似于你要從發霉閣樓的盒子里找一樣特定的東西。當你要找那個東西時,首先要從閣樓里找到盒子。當你請求一個變量時服務器也是一樣,當遇到你請求的哪個變量時觸發執行,然后再去請求那些不會引起執行點的變量。

*技巧12:使用"option explicit"
在asp文件中寫上<% option explicit%>。和c不同,vb允許你在不強制定義變量之前就可以使用該變量。把option explicit打開有助于識別沒定義的變量,使用沒定義的變量就會出現錯誤提示信息。同時也可以使那些沒申明的局部變量非法。沒申明的局部變量和全局變量一樣慢(比定義過的局部變量要慢一倍)。把option explicit打開自然能幫你把這些小蟲子從你的代碼中去掉。

*技巧13:將采集到的值拷貝到本地(局部)變量當中
如果有一些值是你要反復用到的話,把這些值用局部變量的形式拷貝到客戶端。每次當你要用到這些值時,就省去了你去那一堆值里面去找了,這樣也就加快了腳本運行速度。

*技巧14:謹慎使用session對象
使用session對象可以存儲一些用戶特殊信息。當用戶在該應用程序的不同頁之間跳轉,存放在session 中的變量不會丟失,相反,這些變量在整個用戶過程中一直保留。當一個頁面被一個未有session的用戶請求時,web服務器會自動建立一個session對象。當session的時間限制到了或是被中斷了時,服務器就會撤消session對象。為了避免這種情況,你可以把session屬性關閉。然而在iis3.0中在每個應用中的session屬性不能關閉。把整個服務器中的session關閉速度會快一些,但這樣會損失很多功能。最好是需要時謹慎使用session對象
當你在整個應用中都用到session對象時,注意要快點用,否則session對象將會被重置。在iis4.0中,每個應用基礎中的session狀態都可以被激活,也可以在specified.asp文件中被取消。

*技巧15:做性能測試
這就沒什么好翻的,一把好刀就是要多磨一磨,好程序也是一樣,多用用,就知道毛病在哪了 。
調諧不是技術,是藝術!
優化你的程序不是一件小事,需要你從一點一滴做起,從每一個細節做起,并且養成良好的編程習慣。我是學語言的,喜歡有嚴正的風格。

作者:http://www.zhujiangroad.com
來源:http://www.zhujiangroad.com