關于ASP變量和對像關閉與不關閉的差別測試
當前位置:點晴教程→知識管理交流
→『 技術文檔交流 』
[p] 對于asp程序,用到的變量有全局變量,以及一些建立的對象。良好的asp程序員都有釋放它們的習慣,但釋放與不釋[br]放之間到底有多少差別呢?所以今天特地對它們進行了一翻測試。 [/p]
[p] 測試內容:測試的全局變量有一個,對象是采用連接sql的connection對象。[br] 第一次測試:不釋放全局變量而結束程序執行。[br] 第二次測試:釋放全局變量而結束程序執行。[br] 測試前準備:在運行測試前等待服務器休息5分鐘,保證內容及cpu已經穩定下來。[br] 測試軟硬件:服務器為平常的piii550,內存256m。裝有win2000+iis5.0+sql2000[br] 客戶端一臺為win2000,采用ie5.5,開一個瀏覽窗口[br]另一客戶端是win98,ie5.0,開兩個瀏覽窗口[/p] [p] 共測試次數:三個客戶端累計執行到20000停止。[/p] [p]第一次測試報告(不釋放):[/p] [p]開始時內存占用:146464k[br]開始一個客戶端后內存占用:146996k cpu資源占用31-32%[br]開始兩個客戶端內存占用:147316k cpu資源占用49-52%[br]后面的內存變化為 -> 147304k -> 147328[br]開始三個客戶端內存占用:147868k cpu資源占用59-69%[br]后面的內存變化為 -> 147868k -> 147864k -> 147856k -> 147724k -> 147828k[br]-> 147860k -> 147868k -> 148084k -> 148076k -> 148088k[br]-> 148040k -> 147940k[br]結束時內存占用:147940k[br]三個客戶端停止請求后內存釋放情況:[br]147940k -> 148000k -> 147988k -> 146472k -> 146448k -> 146452k[/p] [p] [/p] [p]第二次測試報告(釋放):[/p] [p]開始時內存占用:146652k[br]開始一個客戶端后內存占用:146996k cpu資源占用35-38%[br]開始兩個客戶端內存占用:147700k cpu資源占用55-62%[br]開始三個客戶端內存占用:148252k cpu資源占用53-71%[br]后面的內存變化為 -> 148248k -> 148060k [br]....[br]-> 148080k -> 148076k[br]結束時內存占用:147940k[br]三個客戶端停止請求后內存釋放情況:[br]148076k -> 147956k -> .... -> 146452[/p] [p]下面是兩次測試在結束客戶端穩定下來的內存差別:[/p] [p]第一次:146464-146716 = 252k[br]第二次:146652-146452 = -200k[/p] [p]第一次耗去了內存約252k,最好服務器好像再也釋放不掉了[br]第二次很奇怪,到最后內存卻節約了200k,不知是什原因。[/p] [p]下面是兩次開始測試和結束測試一瞬時的內存使用情況:[/p] [p]第一次:146464-147940 = 3476k[br]第二次:146652-148076 = 1324k[/p] [p]內存使用情況第一次比第二次多了將近一倍。[/p] [p]這次測試說明釋放變量還是有益處的,特別是當系統長期運行的,更是要注意釋放變量,放可保證服務器資源不會白[br]白浪費而到窮盡。[/p] [p]----------------------------------------------------------[/p] [p]附部分測試代碼test.asp:[/p] [p]<%option explicit[br]if request("qian")="qian" then[br]application("testnumer") =0[br]response.write "重置為0!"[br]response.end[br]end if[br]if application("testnumer") > 20000 then[br]response.write "結束!!已經達到2000次"[br]response.end[br]end if[br]%>[br][br][br][br][br] [p][/p] [p][br][/p] [p]<%dim yp[br]application("testnumer") = application("testnumer") + 1[br]response.write "testnumer: " & application("testnumer")[br]initdatabase("yp")[br]initdatabase("yp")[br]initdatabase("yp")[br]initdatabase("yp")[br]yp=second(time)[br]set yp=nothing[br]closedatabase%>[/p] 該文章在 2010/7/8 0:31:04 編輯過 |
關鍵字查詢
相關文章
正在查詢... |