asp.net中c#實(shí)現(xiàn)手動(dòng)回收內(nèi)存的方法
來(lái)源:易賢網(wǎng) 閱讀:1104 次 日期:2015-01-04 11:37:42
溫馨提示:易賢網(wǎng)小編為您整理了“asp.net中c#實(shí)現(xiàn)手動(dòng)回收內(nèi)存的方法”,方便廣大網(wǎng)友查閱!

c#有自動(dòng)回收內(nèi)存的機(jī)制,但是有時(shí)自動(dòng)回收有一定滯后,需要在變量使用后迅速回收,節(jié)約內(nèi)存,這里介紹一個(gè)最簡(jiǎn)單的方法。

1.先對(duì)對(duì)象賦值 null;

2.使用system.gc.collect()

復(fù)制代碼 代碼如下:class program

{

static void main(string[] args)

{

long lenth = 1024 * 1024 * 128;

getcost(程序啟動(dòng));

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>

/// 顯示內(nèi)存使用的狀態(tài)

/// </summary>

/// <param name=state></param>

static void getcost(string state)

{

console.write(當(dāng)前狀態(tài): + state + ; 占用內(nèi)存:);

using (var p1 = new performancecounter(process, working set - private, gctest.vshost))

{

console.writeline( (p1.nextvalue()/1024/1024).tostring(0.0)+mb);

}

}

}

不手動(dòng)回收時(shí),系統(tǒng)會(huì)等到程序執(zhí)行結(jié)束時(shí)回收。在使用data=null后表示該數(shù)據(jù)已經(jīng)不再使用,system.gc.collect();通知系統(tǒng)立即進(jìn)行一次回收操作,根據(jù)c#的內(nèi)存管理原則,不再使用的變量被回

其實(shí)的一些方法總結(jié)

訪問(wèn)數(shù)據(jù)庫(kù)資源需要?jiǎng)?chuàng)建連接、打開(kāi)連接和關(guān)閉連接幾個(gè)操作。這些過(guò)程需要多次與數(shù)據(jù)庫(kù)交換信息以通過(guò)身份驗(yàn)證,比較耗費(fèi)服務(wù)器資源。asp.net中提供了連接池(connection pool)改善打開(kāi)和關(guān)閉數(shù)據(jù)庫(kù)對(duì)性能的影響。系統(tǒng)將用戶的數(shù)據(jù)庫(kù)連接放在連接池中,需要時(shí)取出,關(guān)閉時(shí)收回連接,等待下一次的連接請(qǐng)求。   連接池的大小是有限的,如果在連接池達(dá)到最大限度后仍要求創(chuàng)建連接,必然大大影響性能。因此,在建立數(shù)據(jù)庫(kù)連接后只有在真正需要操作時(shí)才打開(kāi)連接,使用完畢后馬上關(guān)閉,從而盡量減少數(shù)據(jù)庫(kù)連接打開(kāi)的時(shí)間,避免出現(xiàn)超出連接限制的情況。用(推薦)

復(fù)制代碼 代碼如下:using(

sqlconnection conn=new sqlconnection(connstr))

{

}

//不必顯示關(guān)閉或

try{

conn.open();}catch{}finally{conn.close();

}

還有一些網(wǎng)友說(shuō)建議使用緩存技術(shù),

復(fù)制代碼 代碼如下:<%@ outputcache duration=180 varybyparam=none %>

這樣既可以減緩網(wǎng)站的壓力,又能定時(shí)回收部分內(nèi)存資源

數(shù)據(jù)緩存數(shù)據(jù)緩存是一種強(qiáng)大而又非常簡(jiǎn)單的緩存機(jī)制,它可以在緩存區(qū)中為每個(gè)應(yīng)用程序保存各種對(duì)象,這些對(duì)象可以根據(jù)http的請(qǐng)求被調(diào)用,但是在各個(gè)不同的應(yīng)用程序中這些對(duì)象都是私有的。數(shù)據(jù)緩存是通過(guò)cache類(lèi)來(lái)實(shí)現(xiàn)的。當(dāng)應(yīng)用程序建立時(shí),一個(gè)cache類(lèi)就同時(shí)被建立,緩存實(shí)例的生存周期就是應(yīng)用程序的生存周期,它會(huì)隨著應(yīng)用程序的重新運(yùn)行而重建,通過(guò)cache類(lèi)的方法,我們可以將數(shù)據(jù)對(duì)象放入緩存區(qū),然后通過(guò)關(guān)鍵字匹配尋找并使用這些對(duì)象。cache類(lèi)通過(guò)一個(gè)借口來(lái)控制所有需要緩存的內(nèi)容,包括規(guī)定緩存的時(shí)間和緩存方式.

可以通過(guò)如下方法添加緩存對(duì)象:cache[關(guān)鍵字] = 關(guān)鍵字的取值;然后通過(guò)下面的方法來(lái)訪問(wèn)這個(gè)對(duì)象:

復(fù)制代碼 代碼如下:string mkeyvalue = ;

if(cache[關(guān)鍵字] != null)

{

mkeyvalue = cache[關(guān)鍵字];

}

希望本文所述對(duì)大家的asp.net程序設(shè)計(jì)有所幫助。

更多信息請(qǐng)查看IT技術(shù)專(zhuān)欄

更多信息請(qǐng)查看網(wǎng)頁(yè)制作
易賢網(wǎng)手機(jī)網(wǎng)站地址:asp.net中c#實(shí)現(xiàn)手動(dòng)回收內(nèi)存的方法
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門(mén)公布的正式信息和咨詢?yōu)闇?zhǔn)!
相關(guān)閱讀網(wǎng)頁(yè)制作

2025國(guó)考·省考課程試聽(tīng)報(bào)名

  • 報(bào)班類(lèi)型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢 | 簡(jiǎn)要咨詢須知 | 加入群交流 | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專(zhuān)用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
咨詢QQ:526150442(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專(zhuān)用圖標(biāo)