C#有自動回收內存的機制,但是有時自動回收有一定滯後,需要在變量使用後迅速回收,節約內存,這裡介紹一個最簡單的方法。
1.先對對象賦值 null;
2.使用System.GC.Collect()
復制代碼 代碼如下:class Program
{
static void Main(string[] args)
{
long lenth = 1024 * 1024 * 128;
GetCost("程序啟動");
double[] data = new double[lenth];
for (int i = 0; i < lenth; i++)
{
data[i] = double.MaxValue;
}
GetCost("數據制造完成");
data = null;
GetCost("data = null");
System.GC.Collect();
GetCost("System.GC.Collect()");
Console.ReadKey();
}
/// <summary>
/// 顯示內存使用的狀態
/// </summary>
/// <param name="state"></param>
static void GetCost(string state)
{
Console.Write("當前狀態:" + state + "; 占用內存:");
using (var p1 = new PerformanceCounter("Process", "Working Set - Private", "GCtest.vshost"))
{
Console.WriteLine( (p1.NextValue()/1024/1024).ToString("0.0")+"MB");
}
}
}
不手動回收時,系統會等到程序執行結束時回收。在使用data=null後表示該數據已經不再使用,System.GC.Collect();通知系統立即進行一次回收操作,根據C#的內存管理原則,不再使用的變量被回
其實的一些方法總結
訪問數據庫資源需要創建連接、打開連接和關閉連接幾個操作。這些過程需要多次與數據庫交換信息以通過身份驗證,比較耗費服務器資源。ASP.NET中提供了連接池(Connection Pool)改善打開和關閉數據庫對性能的影響。系統將用戶的數據庫連接放在連接池中,需要時取出,關閉時收回連接,等待下一次的連接請求。 連接池的大小是有限的,如果在連接池達到最大限度後仍要求創建連接,必然大大影響性能。因此,在建立數據庫連接後只有在真正需要操作時才打開連接,使用完畢後馬上關閉,從而盡量減少數據庫連接打開的時間,避免出現超出連接限制的情況。用(推薦)
復制代碼 代碼如下:using(
SqlConnection Conn=new SqlConnection(connstr))
{
}
//不必顯示關閉或
try{
conn.Open();}catch{}finally{conn.Close();
}
還有一些網友說建議使用緩存技術,
復制代碼 代碼如下:<%@ OutputCache Duration="180" VaryByParam="None" %>
這樣既可以減緩網站的壓力,又能定時回收部分內存資源
數據緩存數據緩存是一種強大而又非常簡單的緩存機制,它可以在緩存區中為每個應用程序保存各種對象,這些對象可以根據http的請求被調用,但是在各個不同的應用程序中這些對象都是私有的。數據緩存是通過Cache類來實現的。當應用程序建立時,一個Cache類就同時被建立,緩存實例的生存周期就是應用程序的生存周期,它會隨著應用程序的重新運行而重建,通過Cache類的方法,我們可以將數據對象放入緩存區,然後通過關鍵字匹配尋找並使用這些對象。Cache類通過一個借口來控制所有需要緩存的內容,包括規定緩存的時間和緩存方式.
可以通過如下方法添加緩存對象:Cache["關鍵字"] = 關鍵字的取值;然後通過下面的方法來訪問這個對象:
復制代碼 代碼如下:string mKeyValue = "";
if(Cache["關鍵字"] != null)
{
mKeyValue = Cache["關鍵字"];
}
希望本文所述對大家的asp.net程序設計有所幫助。