程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> ASP.NET >> ASP.NET基礎 >> ASP.NET性能優化八條建議

ASP.NET性能優化八條建議

編輯:ASP.NET基礎
1、數據庫訪問性能優化
A、盡量減少數據庫連接,並充分利用每次數據庫連接:連接的創建、打開和關閉是有開銷的。可以使用連接池
B、合理使用存儲過程:存儲過程是存儲在服務器端的一組預編譯的SQL。使用存儲過程可以避免對SQL的多次編譯,後續查詢可以復用之前的執行計劃。另外存儲過程可以減少SQL語句網絡傳輸開銷
C、優化SQL語句:這個就太多了,如合理使用索引、視圖,避免復雜子查詢
2、字符串操作性能優化
A、使用值類型的ToString()方法
對不同類型進行 + 連接時,會發生裝箱操作轉化為引用類型再添加到字符串中。裝箱操作會在托管堆中分配一個新對象,將原有的值復制到新對象中,代價很高。使用ToString()方法可以避免裝箱,從而提高性能
B、利用StringBuilder類
3、禁用調試模式
4、只要合適,盡量緩存數據和頁面輸出
5、不要依賴代碼中的異常來控制程序正常流程
異常的開銷是很大的。所以慎用異常。
6、使用Page.IsPostBack避免往返過程的不必要處理
復制代碼 代碼如下:
void Page_Load(Object sender, EventArgs e) // Set up a connection and command
{
if (!Page.IsPostBack) // 第一次加載時才填充數據
{
String query = "select * from Authors where FirstName like '%JUSTIN%'";
myCommand.Fill(ds, "Authors");
myDataGrid.DataBind();
}
}

7、如果不使用會話狀態,可以禁用它或者設置只讀
A、若要禁用頁的會話狀態,請將 @ Page 指令中的 EnableSessionState 屬性設置為false。例如:
復制代碼 代碼如下:
<%@ Page EnableSessionState="false" %>

B、注意如果頁需要訪問會話變量,但不打算創建或修改它們,則將 @ Page 指令中的 EnableSessionState 屬性設置為 ReadOnly。
8、利用成熟的工具進行性能測試
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved