主頁(yè) > 知識(shí)庫(kù) > asp.net中C#實(shí)現(xiàn)手動(dòng)回收內(nèi)存的方法

asp.net中C#實(shí)現(xiàn)手動(dòng)回收內(nèi)存的方法

熱門(mén)標(biāo)簽:400免費(fèi)電話怎么辦理 河北網(wǎng)絡(luò)回?fù)芡夂粝到y(tǒng) 外呼電銷(xiāo)機(jī)器人軟件 威海電銷(xiāo) t3出行地圖標(biāo)注怎么做 河南語(yǔ)音外呼系統(tǒng)公司 寧夏機(jī)器人電銷(xiāo) 關(guān)于宗地圖標(biāo)注技術(shù)規(guī)范 400電話辦理最優(yōu)質(zhì)

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)實(shí)現(xiàn)的。當(dāng)應(yīng)用程序建立時(shí),一個(gè)Cache類就同時(shí)被建立,緩存實(shí)例的生存周期就是應(yīng)用程序的生存周期,它會(huì)隨著應(yīng)用程序的重新運(yùn)行而重建,通過(guò)Cache類的方法,我們可以將數(shù)據(jù)對(duì)象放入緩存區(qū),然后通過(guò)關(guān)鍵字匹配尋找并使用這些對(duì)象。Cache類通過(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ì)有所幫助。

您可能感興趣的文章:
  • .Net Core內(nèi)存回收模式及性能測(cè)試對(duì)比分析
  • .Net程序內(nèi)存異常的原因及解決
  • 一篇文章教你如何排查.NET內(nèi)存泄漏

標(biāo)簽:廣元 樂(lè)山 咸寧 固原 吉林 池州 賀州 淮北

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《asp.net中C#實(shí)現(xiàn)手動(dòng)回收內(nèi)存的方法》,本文關(guān)鍵詞  asp.net,中,實(shí)現(xiàn),手動(dòng),回收,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《asp.net中C#實(shí)現(xiàn)手動(dòng)回收內(nèi)存的方法》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于asp.net中C#實(shí)現(xiàn)手動(dòng)回收內(nèi)存的方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章