c#有自動回收內存的機制,但是有時自動回收有一定滯后,需要在變量使用后迅速回收,節(jié)約內存,這里介紹一個最簡單的方法。
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(數(shù)據(jù)制造完成);
data = null;
getcost(data = null);
system.gc.collect();
getcost(system.gc.collect());
console.readkey();
}
/// <summary>
/// 顯示內存使用的狀態(tài)
/// </summary>
/// <param name=state></param>
static void getcost(string state)
{
console.write(當前狀態(tài): + state + ; 占用內存:);
using (var p1 = new performancecounter(process, working set - private, gctest.vshost))
{
console.writeline( (p1.nextvalue()/1024/1024).tostring(0.0)+mb);
}
}
}
不手動回收時,系統(tǒng)會等到程序執(zhí)行結束時回收。在使用data=null后表示該數(shù)據(jù)已經不再使用,system.gc.collect();通知系統(tǒng)立即進行一次回收操作,根據(jù)c#的內存管理原則,不再使用的變量被回
其實的一些方法總結
訪問數(shù)據(jù)庫資源需要創(chuàng)建連接、打開連接和關閉連接幾個操作。這些過程需要多次與數(shù)據(jù)庫交換信息以通過身份驗證,比較耗費服務器資源。asp.net中提供了連接池(connection pool)改善打開和關閉數(shù)據(jù)庫對性能的影響。系統(tǒng)將用戶的數(shù)據(jù)庫連接放在連接池中,需要時取出,關閉時收回連接,等待下一次的連接請求。 連接池的大小是有限的,如果在連接池達到最大限度后仍要求創(chuàng)建連接,必然大大影響性能。因此,在建立數(shù)據(jù)庫連接后只有在真正需要操作時才打開連接,使用完畢后馬上關閉,從而盡量減少數(shù)據(jù)庫連接打開的時間,避免出現(xiàn)超出連接限制的情況。用(推薦)
復制代碼 代碼如下:using(
sqlconnection conn=new sqlconnection(connstr))
{
}
//不必顯示關閉或
try{
conn.open();}catch{}finally{conn.close();
}
還有一些網友說建議使用緩存技術,
復制代碼 代碼如下:<%@ outputcache duration=180 varybyparam=none %>
這樣既可以減緩網站的壓力,又能定時回收部分內存資源
數(shù)據(jù)緩存數(shù)據(jù)緩存是一種強大而又非常簡單的緩存機制,它可以在緩存區(qū)中為每個應用程序保存各種對象,這些對象可以根據(jù)http的請求被調用,但是在各個不同的應用程序中這些對象都是私有的。數(shù)據(jù)緩存是通過cache類來實現(xiàn)的。當應用程序建立時,一個cache類就同時被建立,緩存實例的生存周期就是應用程序的生存周期,它會隨著應用程序的重新運行而重建,通過cache類的方法,我們可以將數(shù)據(jù)對象放入緩存區(qū),然后通過關鍵字匹配尋找并使用這些對象。cache類通過一個借口來控制所有需要緩存的內容,包括規(guī)定緩存的時間和緩存方式.
可以通過如下方法添加緩存對象:cache[關鍵字] = 關鍵字的取值;然后通過下面的方法來訪問這個對象:
復制代碼 代碼如下:string mkeyvalue = ;
if(cache[關鍵字] != null)
{
mkeyvalue = cache[關鍵字];
}
希望本文所述對大家的asp.net程序設計有所幫助。
更多信息請查看IT技術專欄