java語言與c語言的區(qū)別 什么時(shí)候發(fā)生內(nèi)存泄漏?
什么時(shí)候發(fā)生內(nèi)存泄漏?至于Java,Java和C在垃圾收集機(jī)制上有很大的不同。我們不知道會(huì)有這樣的悲劇。如果在C語言中不及時(shí)處理無用的對(duì)象,就會(huì)出現(xiàn)內(nèi)存泄漏。Java會(huì)不會(huì)出現(xiàn)內(nèi)存泄漏?答案是肯定的。
什么時(shí)候發(fā)生內(nèi)存泄漏?
至于Java,Java和C在垃圾收集機(jī)制上有很大的不同。我們不知道會(huì)有這樣的悲劇。如果在C語言中不及時(shí)處理無用的對(duì)象,就會(huì)出現(xiàn)內(nèi)存泄漏。Java會(huì)不會(huì)出現(xiàn)內(nèi)存泄漏?答案是肯定的。我們都知道,在Java中,沒有被引用的對(duì)象是垃圾收集的。如果有推薦信,就讓他們長(zhǎng)壽。但假設(shè)我們考慮這樣一種情況,內(nèi)存中有兩個(gè)對(duì)象,其中一個(gè)對(duì)象的生命周期比另一個(gè)對(duì)象長(zhǎng)得多,生命周期大的對(duì)象引用了生命周期小的對(duì)象,而生命周期小的對(duì)象不再引用其他對(duì)象。既然大對(duì)象引用了小對(duì)象,垃圾收集器引用了小對(duì)象,小對(duì)象就無能為力了。當(dāng)然,一兩個(gè)這樣的對(duì)象是沒有問題的,但是如果生命周期長(zhǎng)的對(duì)象有這么多的引用,我們?cè)撛趺崔k呢?此時(shí),很可能發(fā)生內(nèi)存泄漏。如我剛才所說,防止內(nèi)存泄漏是一個(gè)生命周期問題。好吧,我們可以把它聲明為一個(gè)靜態(tài)變量,這樣生命周期就和應(yīng)用程序的生命周期一樣了。在初始化對(duì)象中也可以為null。
java會(huì)內(nèi)存泄露么?
我會(huì)的。
內(nèi)存泄漏意味著對(duì)象不再使用,但未正確回收,這將導(dǎo)致內(nèi)存泄漏。
盡管JVM有一個(gè)垃圾收集器,但在某些情況下對(duì)象是不可回收的。
Java內(nèi)存泄漏的主要原因是長(zhǎng)生命周期對(duì)象指的是短生命周期對(duì)象,這使得短生命周期對(duì)象無法回收。
例如,集合中引用的對(duì)象沒有清理策略,因此不會(huì)回收沒有清理策略的對(duì)象,從而導(dǎo)致內(nèi)存泄漏。
Java中有四種引用:強(qiáng)引用、軟引用、弱引用和虛擬引用。通常,我們聲明的變量是強(qiáng)引用。你可以學(xué)習(xí)其他類型的參考資料。即使它們被引用,它們也會(huì)在不同的場(chǎng)景中被回收。