成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

最近一周,十人面試,十人全掛在這個問題上!

開發 前端
在JVM的即時編譯語境下,逃逸分析將判斷新建的對象是否逃逸。即時編譯判斷對象是否逃逸的依據:一種是對象是否被存入堆中(靜態字段或者堆中對象的實例字段),另一種就是對象是否被傳入未知代碼。

從開始學習Java的時候,我們就接觸了這樣一種觀點:Java中的對象是在堆上創建的,對象的引用是放在棧里的,這個觀點真的是正確的嗎?

關于面試題

面試題:Java中的對象是在堆上分配的嗎?

有些小伙伴心里會想:我從一開始學習Java時,就知道了:Java中的對象是在堆上創建的,對象的引用是存儲到棧中的,那Java中的對象是在堆上分配的啊!難道不是嗎?

如果你這樣回答,就會被直接Pass掉。

或許有些小伙伴還是不太明白,那我們繼續往下看。

面試題答案

首先,我們先給出這個題目的答案,這里我先簡短的回答下這個面試題,后續我們會進行相關分析。

你可以這樣回答:Java中的對象不一定是在堆上分配的,因為JVM通過逃逸分析,能夠分析出一個新對象的使用范圍,并以此確定是否要將這個對象分配到堆上。

這里,我們接觸了一個新名詞:逃逸分析。相信很多小伙伴不是很明白,那我們繼續往下看。

逃逸分析的概念

先以官方的形式來說下什么是逃逸分析。逃逸分析就是:一種確定指針動態范圍的靜態分析,它可以分析在程序的哪些地方可以訪問到指針。

在JVM的即時編譯語境下,逃逸分析將判斷新建的對象是否逃逸。即時編譯判斷對象是否逃逸的依據:一種是對象是否被存入堆中(靜態字段或者堆中對象的實例字段),另一種就是對象是否被傳入未知代碼。

直接說這些概念,確實有點暈啊,那我們就來兩個示例。

對象逃逸示例

一種典型的對象逃逸就是:對象被復制給成員變量或者靜態變量,可能被外部使用,此時變量就發生了逃逸。

我們可以用下面的代碼來表示這個現象。

/**
 * @author binghe
 * @description 對象逃逸示例1
 */
public class ObjectEscape{
    private User user;
    public void init(){
        user = new User();
    }
}

在ObjectEscape類中,存在一個成員變量user,我們在init()方法中,創建了一個User類的對象,并將其賦值給成員變量user。此時,對象被復制給了成員變量,可能被外部使用,此時的變量就發生了逃逸。

另一種典型的場景就是:對象通過return語句返回。如果對象通過return語句返回了,此時的程序并不能確定這個對象后續會不會被使用,外部的線程可以訪問到這個變量,此時對象也發生了逃逸。

我們可以用下面的代碼來表示這個現象。

/**
 * @author binghe
 * @description 對象逃逸示例2
 */
public class ObjectReturn{
    public User createUser(){
        User user = new User();
        return user;
    }
}

給出兩個示例,相信小伙伴們對JVM的逃逸分析多少有點了解了吧,沒錯,JVM通過逃逸分析,能夠分析出新對象的使用范圍,從而決定新對象是否要在堆上進行分配。

還沒完,我們繼續看下逃逸分析的優點,以便于小伙伴們能夠更好的理解逃逸分析。

逃逸分析的優點

逃逸分析的優點總體上來說可以分為三個:對象可能分配在棧上、分離對象或標量替換、消除同步鎖。我們可以使用下圖來表示。

圖片

對象可能分配在棧上

JVM通過逃逸分析,分析出新對象的使用范圍,就可能將對象在棧上進行分配。棧分配可以快速地在棧幀上創建和銷毀對象,不用再將對象分配到堆空間,可以有效地減少 JVM 垃圾回收的壓力。

分離對象或標量替換

當JVM通過逃逸分析,確定要將對象分配到棧上時,即時編譯可以將對象打散,將對象替換為一個個很小的局部變量,我們將這個打散的過程叫做標量替換。將對象替換為一個個局部變量后,就可以非常方便的在棧上進行分配了。

同步鎖消除

如果JVM通過逃逸分析,發現一個對象只能從一個線程被訪問到,則訪問這個對象時,可以不加同步鎖。如果程序中使用了synchronized鎖,則JVM會將synchronized鎖消除。

這里,需要注意的是:這種情況針對的是synchronized鎖,而對于Lock鎖,則JVM并不能消除。

要開啟同步消除,需要加上 -XX:+EliminateLocks 參數。因為這個參數依賴逃逸分析,所以同時要打開 -XX:+DoEscapeAnalysis 選項。

所以,并不是所有的對象和數組,都是在堆上進行分配的,由于即時編譯的存在,如果JVM發現某些對象沒有逃逸出方法,就很有可能被優化成在棧上分配。

責任編輯:姜華 來源: 冰河技術
相關推薦

2018-09-27 15:42:15

Python編程語言技術

2021-12-17 10:20:39

Nature事件科學

2011-04-22 09:41:53

惠普佳能聯想

2016-07-28 16:30:28

餓了么技術團隊WOT2016

2021-10-15 10:28:19

技術達摩院研究

2022-08-26 15:25:46

網絡安全技術

2019-04-26 15:38:34

Hadoop集群存儲

2022-11-08 09:46:59

推特馬斯克

2023-11-27 07:37:50

面試協程池

2009-12-24 09:38:07

2023-09-13 07:06:40

開源技術

2013-07-15 13:31:09

思科P+計劃思科

2011-04-25 15:28:08

噴墨打印機

2013-09-25 14:47:15

遠程控制SDK

2014-12-15 09:23:36

2017-04-06 10:29:46

深信服亞太區巡展

2011-12-29 15:19:00

魅族PC套件

2019-03-04 15:53:02

SQL存儲系統

2012-12-30 21:22:08

移動辦公Windows Ser

2011-11-27 16:51:00

一周新聞回顧
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 在线欧美 | 国产剧情一区 | 国产精品福利在线观看 | 三级av在线| 九九热在线视频观看这里只有精品 | 精品久久影院 | 91porn国产成人福利 | 日韩国产精品一区二区三区 | 欧美久久久久久久久中文字幕 | 欧美精品久久一区 | 欧美精品久久久久久 | 亚洲视频免费在线播放 | 免费v片在线观看 | www.干| 黄色在线免费网站 | 国产激情视频在线观看 | 久久久久久国产精品 | 成人在线免费电影 | 爱爱视频日本 | 在线视频一区二区三区 | 亚洲精品久久久蜜桃 | 高清视频一区二区三区 | 色综合天天天天做夜夜夜夜做 | 欧美一区 | 国产成人精品一区二区三区四区 | 中文字幕av亚洲精品一部二部 | 国产资源视频 | av男人的天堂av | 秋霞电影院午夜伦 | 欧美日韩在线一区二区三区 | 国产999精品久久久久久绿帽 | 中文字幕日本一区二区 | 欧美一区免费在线观看 | 欧美夜夜 | 国产精品久久久久免费 | 2020亚洲天堂 | 怡红院免费的全部视频 | av黄色国产 | 亚洲视频精品在线 | 免费在线视频一区二区 | 久久久久中文字幕 |