是不是代碼會占用空間,如果一個程式初始化需要 100M 的代碼,那麼在他初始化之後,這些代碼就沒有作用了,他會不會占空間?本文經過測試發現,代碼也是會占空間 ...
是不是代碼會占用空間,如果一個程式初始化需要 100M 的代碼,那麼在他初始化之後,這些代碼就沒有作用了,他會不會占空間?本文經過測試發現,代碼也是會占空間。
我寫了2k個垃圾類代碼,然後把他放在一個項目 BhgpsWnb,使用另一個項目去引用他。是不是覺得軟體在運行的時候就需要很多的記憶體來放代碼?
引用垃圾程式的項目是 ReKlnma ,先只是在引用添加項目引用,然後在不使用 BhgpsWnb 這個項目的代碼,我運行下麵的代碼
static void Main(string[] args)
{
Console.ReadKey();
}
占用 7 M 記憶體,而如果運行了存在 2k 垃圾代碼 BhgpsWnb 程式,就需要 8M 。使用方法是創建一個類,這個類就是垃圾代碼裡面的一個,這樣就需要把dll放在記憶體。
static void Main(string[] args)
{
var ablkekbuuimc = new Ablkekbuuimc();
ablkekbuuimc.Aaxfyerenjmfe(2);
Console.ReadKey();
}
如果覺得因為創建一個類需要的記憶體太大,那麼我使用下麵的代碼,只是拿到一個類型,但是需要的記憶體是 8M 因為程式會把另一個程式載入
static void Main(string[] args)
{
Type t = typeof(Ablkekbuuimc);
Console.ReadKey();
}
下麵來換個方式寫,取消對垃圾程式的直接引用。使用 Load 方法去載入,可以看到垃圾程式 BhgpsWnb 有 8M ,一般的庫可沒有那麼大。
static void Main(string[] args)
{
var file = new FileInfo("BhgpsWnb.exe");
Assembly.LoadFile(file.FullName);
Console.ReadKey();
}
結果使用記憶體需要 8M 多,所以代碼也是需要記憶體的,一旦載入了就不會從程式集卸載。
如果是載入程式集,那麼載入程式集就需要很多的記憶體,即使卸載程式也沒有用
static void Main(string[] args)
{
var app = Load();
GC.Collect();
GC.WaitForFullGCComplete();
Console.ReadKey();
AppDomain.Unload(app);
Console.ReadKey();
GC.Collect();
GC.WaitForFullGCComplete();
}
private static AppDomain Load()
{
var file = new FileInfo("BhgpsWnb.exe");
var otherAssemblyBytes = File.ReadAllBytes(file.FullName);
var app = AppDomain.CreateDomain("BhgpsWnb");
app.Load(otherAssemblyBytes);
return app;
}
上面的代碼使用了 Load 就需要 20M的記憶體,在後面使用 Unload 之後實際上記憶體也沒有減少,所以建議不要使用程式集載入方式,這個方式使用很多記憶體。
可以通過指定名稱載入,可以看到下麵的代碼需要使用記憶體比較小,需要 9M ,但是 Unload 之後沒有減少記憶體
static void Main(string[] args)
{
var app = Load();
GC.Collect();
GC.WaitForFullGCComplete();
Console.ReadKey();
AppDomain.Unload(app);
GC.Collect();
GC.WaitForFullGCComplete();
Console.ReadKey();
}
private static AppDomain Load()
{
var file = new FileInfo("BhgpsWnb.exe");
var app = AppDomain.CreateDomain("BhgpsWnb", null, file.DirectoryName, file.DirectoryName, false);
app.Load("BhgpsWnb, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null");
return app;
}
所以在載入 dll ,千萬不要使用把文件作為 byte 讀出來,然後載入,這個方法需要很多的記憶體。
本作品採用知識共用署名-非商業性使用-相同方式共用 4.0 國際許可協議進行許可。歡迎轉載、使用、重新發佈,但務必保留文章署名林德熙(包含鏈接:http://blog.csdn.net/lindexi_gd ),不得用於商業目的,基於本文修改後的作品務必以相同的許可發佈。如有任何疑問,請與我聯繫。