摘要:,用于調(diào)用垃圾收集器,在調(diào)用時(shí),垃圾收集器將運(yùn)行以回收未使用的內(nèi)存空間。然而調(diào)用附帶一個免責(zé)聲明,無法保證對垃圾收集器的調(diào)用。所以并不能說是完美主動進(jìn)行了垃圾回收。
歡迎進(jìn)入JAVA基礎(chǔ)課程
博客地址:https://blog.csdn.net/houjiyu...
本系列文章將主要針對JAVA一些基礎(chǔ)知識點(diǎn)進(jìn)行講解,為平時(shí)歸納所總結(jié),不管是剛接觸JAVA開發(fā)菜鳥還是業(yè)界資深人士,都希望對廣大同行帶來一些幫助。若有問題請及時(shí)留言或加QQ:243042162。
寄語:數(shù)據(jù)類型
經(jīng)歷過國考、省考,參加過各種證書考試,無疑對于上了年紀(jì)的人來說時(shí)刻有著莫大的危機(jī)感,時(shí)刻想著如何擺脫目前的困境。經(jīng)常跟身邊的同事去討論20年后你在這個行業(yè)處于什么位置,當(dāng)想想如果20年后還處于現(xiàn)在的位置是多么可怕的一件事情。悟性可以差點(diǎn),時(shí)間可晚點(diǎn),但學(xué)習(xí)跟積累必須跟上,與時(shí)俱進(jìn),搬磚人才可能脫胎換骨,收割事業(yè)的成就感與滿足感。
1. 基礎(chǔ)數(shù)據(jù)類型:
數(shù)值型
整型數(shù)據(jù)(byte |short |int |long)
浮點(diǎn)類型(float |double)
字符型(char)
布爾型(boolean)
2. 引用數(shù)據(jù)類型:
類(class)
接口(interface)
數(shù)組
注意事項(xiàng)垃圾回收機(jī)制
&:左右都判斷,可作位運(yùn)算和邏輯與運(yùn)算符
&&:左假則結(jié)束,左真判斷右,可作邏輯與運(yùn)算符
之前網(wǎng)絡(luò)上見過兩個很搞笑的圖比喻C語言和JAVA之間的垃圾回收機(jī)制,如下圖所示
C語言
JAVA語言
(1)C的垃圾回收是人工的,工作量大,但是可控性高。1. 確定哪些對象要進(jìn)行回收
(2)JAVA是自動化的,但是可控性很差,甚至有時(shí)會出現(xiàn)內(nèi)存溢出的情況。
(3)System.gc(),用于調(diào)用垃圾收集器,在調(diào)用時(shí),垃圾收集器將運(yùn)行以回收未使用的內(nèi)存空間。它將嘗試釋放被丟棄對象占用的內(nèi)存。然而System.gc()調(diào)用附帶一個免責(zé)聲明,無法保證對垃圾收集器的調(diào)用。所以System.gc()并不能說是完美主動進(jìn)行了垃圾回收。
經(jīng)典算法:引用計(jì)數(shù)法、可達(dá)性分析算法
2. 什么時(shí)候進(jìn)行回收會在cpu空閑的時(shí)候自動進(jìn)行回收
在堆內(nèi)存存儲滿了之后
主動調(diào)用System.gc()后嘗試進(jìn)行回收
3. 如何回收相關(guān)算法:標(biāo)記-清除算法、復(fù)制算法、標(biāo)記-整理算法、分代收集算法
標(biāo)記-清除算法 (效率和內(nèi)存碎片問題):這是最基礎(chǔ)的一種算法,分為兩個步驟,第一個步驟就是標(biāo)記,也就是標(biāo)記處所有需要回收的對象,標(biāo)記完成后就進(jìn)行統(tǒng)一的回收掉哪些帶有標(biāo)記的對象。這種算法優(yōu)點(diǎn)是簡單,缺點(diǎn)是效率問題,還有一個最大的缺點(diǎn)是空間問題,標(biāo)記清除之后會產(chǎn)生大量不連續(xù)的內(nèi)存碎片,當(dāng)程序在以后的運(yùn)行過程中需要分配較大對象時(shí)無法找到足夠的連續(xù)內(nèi)存而造成內(nèi)存空間浪費(fèi)。
復(fù)制算法(適用于對象存活率低的場景) :復(fù)制將可用內(nèi)存按容量劃分為大小相等的兩塊,每次只使用其中的一塊。當(dāng)這一塊的內(nèi)存用完了,就將還存活著的對象復(fù)制到另外一塊上面,然后再把已使用過的內(nèi)存空間一次清理掉。這樣使得每次都是對其中的一塊進(jìn)行內(nèi)存回收,內(nèi)存分配時(shí)也就不用考慮內(nèi)存碎片等復(fù)雜情況。只是這種算法的代價(jià)是將內(nèi)存縮小為原來的一半。
標(biāo)記整理算法(適用于對象存活率高的場景) :標(biāo)記整理算法與標(biāo)記清除算法很相似,但最顯著的區(qū)別是:標(biāo)記清除算法僅對不存活的對象進(jìn)行處理,剩余存活對象不做任何處理,造成內(nèi)存碎片;而標(biāo)記整理算法不僅對不存活對象進(jìn)行處理清除,還對剩余的存活對象進(jìn)行整理,重新整理,因此其不會產(chǎn)生內(nèi)存碎片。
分代收集算法 (根據(jù)存活周期分為不同的幾塊):分代收集算法是一種比較智能的算法,也是現(xiàn)在jvm使用最多的一種算法,他本身其實(shí)不是一個新的算法,而是他會在具體的場景自動選擇以上三種算法進(jìn)行垃圾對象回收。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.hztianpu.com/yun/74935.html
摘要:歡迎進(jìn)入基礎(chǔ)課程博客地址本系列文章將主要針對一些基礎(chǔ)知識點(diǎn)進(jìn)行講解,為平時(shí)歸納所總結(jié),不管是剛接觸開發(fā)菜鳥還是業(yè)界資深人士,都希望對廣大同行帶來一些幫助。是同步的,而不是。因此,更適合于單線程環(huán)境,而適合于多線程環(huán)境。 歡迎進(jìn)入JAVA基礎(chǔ)課程 博客地址:https://blog.csdn.net/houjiyu...本系列文章將主要針對JAVA一些基礎(chǔ)知識點(diǎn)進(jìn)行講解,為平時(shí)歸納所總...
摘要:歡迎進(jìn)入基礎(chǔ)課程博客地址本系列文章將主要針對一些基礎(chǔ)知識點(diǎn)進(jìn)行講解,為平時(shí)歸納所總結(jié),不管是剛接觸開發(fā)菜鳥還是業(yè)界資深人士,都希望對廣大同行帶來一些幫助。是同步的,而不是。因此,更適合于單線程環(huán)境,而適合于多線程環(huán)境。 歡迎進(jìn)入JAVA基礎(chǔ)課程 博客地址:https://blog.csdn.net/houjiyu...本系列文章將主要針對JAVA一些基礎(chǔ)知識點(diǎn)進(jìn)行講解,為平時(shí)歸納所總...
摘要:注意不僅可以控制事務(wù)傳播行為等,還可以控制事務(wù)隔離級別等。事物的隔離級別隔離級別越高,并發(fā)性能越低。在的隔離級別下,會出現(xiàn)幻讀的問題??纱谢亲罡叩母綦x級別。 歡迎進(jìn)入JAVA基礎(chǔ)課程 博客地址:https://mp.csdn.net/mdeditor/...本系列文章將主要針對JAVA一些基礎(chǔ)知識點(diǎn)進(jìn)行講解,為平時(shí)歸納所總結(jié),不管是剛接觸JAVA開發(fā)菜鳥還是業(yè)界資深人士,都希望對...
摘要:注意不僅可以控制事務(wù)傳播行為等,還可以控制事務(wù)隔離級別等。事物的隔離級別隔離級別越高,并發(fā)性能越低。在的隔離級別下,會出現(xiàn)幻讀的問題??纱谢亲罡叩母綦x級別。 歡迎進(jìn)入JAVA基礎(chǔ)課程 博客地址:https://mp.csdn.net/mdeditor/...本系列文章將主要針對JAVA一些基礎(chǔ)知識點(diǎn)進(jìn)行講解,為平時(shí)歸納所總結(jié),不管是剛接觸JAVA開發(fā)菜鳥還是業(yè)界資深人士,都希望對...
閱讀 2734·2021-11-23 09:51
閱讀 1021·2021-09-24 10:37
閱讀 3727·2021-09-02 15:15
閱讀 2025·2019-08-30 13:03
閱讀 1961·2019-08-29 15:41
閱讀 2689·2019-08-29 14:12
閱讀 1490·2019-08-29 11:19
閱讀 3362·2019-08-26 13:39