1台诗、關(guān)于內(nèi)存
每個(gè)應(yīng)用程序都占用一定的內(nèi)存,因?yàn)閮?nèi)存是有限的,因此需要一個(gè)內(nèi)存管理回收機(jī)制项棠。例如C語(yǔ)言
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main(int argc, char *argv[]) {
? ? char name[20];? //定義數(shù)組
? ? char *pDes = null; //定義指針
? ? strcpy(name, "dddd"); //拷貝
? ? // 申請(qǐng)內(nèi)存
? ? pDes = malloc( 30 * sizeof(char) );
? ? if( pDes == NULL ) {? //判斷
? ? ? ? fprintf(stderr, "Error!\n");
? ? } else {
? ? ? ? strcpy( description, "this is pointer"); //拷貝
? ? }
? ? printf("name = %s\n", name );
? ? printf("pDes: %s\n", pDes );
? ? // 釋放內(nèi)存
? ? free(description);
}
程序中pDes的內(nèi)存是手動(dòng)申請(qǐng)的,需要手動(dòng)釋放挎峦,name數(shù)組是由編譯器自動(dòng)分配釋放香追。詳細(xì)請(qǐng)看 C語(yǔ)言內(nèi)存
在手動(dòng)內(nèi)存管理中,開(kāi)發(fā)者有責(zé)任釋放閑置的內(nèi)存坦胶,這種內(nèi)存管理方式可 能會(huì)造成下面幾個(gè)問(wèn)題:
? ? 1)內(nèi)存泄露: 當(dāng)從不釋放使用過(guò)的內(nèi)存時(shí)發(fā)生
? ? 2)野指針:當(dāng)對(duì)象被釋放時(shí)透典,而原來(lái)的指針仍繼續(xù)使用。在其他數(shù)據(jù)覆蓋寫入或讀取敏感信息時(shí)會(huì)造成嚴(yán)重的安全問(wèn)題
2顿苇、Node.js內(nèi)存管理
Node.js 附帶了一個(gè)垃圾回收器峭咒,你不需要去手動(dòng)管理內(nèi)存分配。
Node.js沒(méi)有進(jìn)行內(nèi)存回收時(shí)纪岁,默認(rèn)最大可使用內(nèi)存是1.5G凑队,通過(guò)以下參數(shù),可以進(jìn)行設(shè)置
node --max_old_space_size=400 server.js --production
GC? (Garbage Collector幔翰;垃圾收集器)是一種自動(dòng)管理應(yīng)用內(nèi)存的機(jī)制漩氨。GC 的工作是回收被未使用的對(duì)象所占用的內(nèi)存西壮。它在 1959 年首次應(yīng)用于 John McCarthy 創(chuàng)造的 LISP 中。GC 判斷對(duì)象不再使用的方式是沒(méi)有其他的對(duì)象引用它們叫惊。
GC運(yùn)行前款青,如果你有一些互相引用的對(duì)象以及一些沒(méi)有任何引用的對(duì)象,如下圖
GC運(yùn)行后赋访,會(huì)將沒(méi)有用的對(duì)象刪除可都,并釋放空間
GC 的優(yōu)點(diǎn):
? ? 1、防止了野指針 bug
? ? 2蚓耽、不用擔(dān)心內(nèi)存的二次釋放
? ? 3渠牲、避免了一些類型的內(nèi)存泄露
? ? 當(dāng)然,使用 GC 不能解決你所有的問(wèn)題步悠,而且它也不是內(nèi)存管理的銀彈签杈。
使用 GC 時(shí)需要注意的事項(xiàng)
? ? 性能影響 - GC 會(huì)消耗計(jì)算能力去決定什么對(duì)象應(yīng)該釋放
? ? 無(wú)法預(yù)測(cè)的停頓 - 現(xiàn)代 GC 實(shí)現(xiàn)嘗試去避免 stop-the-world 的回收方式
3、V8平臺(tái)的內(nèi)存管理
常駐大小:在RAM中被進(jìn)程占用的內(nèi)存大小鼎兽,包括:堆答姥、棧、代碼本身
堆: 包含原始類型和對(duì)象的引用
棧: 存儲(chǔ)引用類型谚咬,像對(duì)象鹦付、字符串或者閉包
對(duì)象淺存儲(chǔ)大小: 存儲(chǔ)對(duì)象本身
對(duì)象保留大性褙浴: 對(duì)象依賴的對(duì)象占用的空間
4敲长、GC運(yùn)行機(jī)制
? ? ? ? 一個(gè)對(duì)象從根節(jié)點(diǎn)不可訪問(wèn),或者不會(huì)被根對(duì)象或任何其他活動(dòng)對(duì)象引用時(shí)秉继, 他就會(huì)被定為垃圾收集的候選對(duì)象祈噪。 根對(duì)象可以是全局對(duì)象,DOM元素或局部變量尚辑。
? ? ? ? 堆有兩個(gè)主要部分辑鲤,新空間和舊空間。 新空間分配新的內(nèi)存杠茬。 在這里收集垃圾的速度很快月褥,大小為1-8MB。 新空間對(duì)象被稱為年輕一代瓢喉。 被垃圾收集器處理過(guò)之后保留先來(lái)的空間被稱為舊空間吓坚,舊空間里的對(duì)象被稱為老一代;舊空間也可以快速的分配內(nèi)存灯荧,只是收集的花費(fèi)昂貴礁击,因此很少執(zhí)行。
? ? ? ? 為什么說(shuō)回收是昂貴的呢,因?yàn)閂8采用的是一種被稱為世界末日(stop-the-world)的回收機(jī)制哆窿。在執(zhí)行的時(shí)候幾乎程序是暫停的链烈。
? ? ? ? 在年青一代變成老一代的過(guò)程中,一般約20%會(huì)保留挚躯,其他的都會(huì)被回收强衡。因此舊空間只有在耗盡的時(shí)候才會(huì)被回收, 為此码荔,V8引擎使用兩種不同的收集算法:
清除收集:快速地運(yùn)行在新一代
標(biāo)記掃描收集:緩慢地運(yùn)行在老一代
內(nèi)存管理? http://www.memorymanagement.org/
V8垃圾回收? http://jayconrod.com/posts/55/a-tour-of-v8-garbage-collection