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

在什么情況下,Java比C++慢很多?

開發 后端
即使沒有逃逸分析,年青代的分配也是通過指針碰撞方式,在線程本地分配緩沖區(TLAB)中完成的,不需要進行同步。所以Java中小對象的分配有 的時候比C語言實現的 malloc() 方式更快。更好的 malloc 方法像Google的 tcmalloc,采用了類似的方式。

問:在什么情況下,Java 比 C++ 慢很多?

答:Ben Maurer:

為了回答這個問題,需要先將該問題分成幾個可能引起慢的原因:

在什么情況下,Java比C++慢很多?

垃圾回收器。這是一把“雙刃劍”。如果你的程序遵循“大部分對象都在年青代中消亡”模型,垃圾回收器是非常有利的(很少的碎片,更好的緩存局部性)。但是,如果程序不遵循該模型,JVM將花費很多資源來回收堆內存。

大對象。在Java中,所有的對象都有一個vtable指針,而C++中使用POD結構沒有額外開銷。此外,所有的Java對象是可以被鎖定的。其 實現依賴于JVM,這可能需要在對象中增加額外的字段。大對象 == 緩存更少的對象 == 更慢。(另一方面,Java 7 用64位記錄壓縮后的指針,這也是造成該問題的一部分原因。

缺乏內聯對象。在Java中,所有的類都是指針。在C++中,對象可以和其它對象一起分配,或者在棧上分配。這樣可以提高緩存的局部性,從而減少動態內存分配的開銷。

平臺函數調用。在Java中,JNI的調用或者將對象編譯成本地代碼都會帶來不小的開銷。如果你需要頻繁調用客戶端的C++代碼,會增加很大的開銷。

低效的強制抽象。例如,在Java中字符串是不可變的。如果你想寫一個XML分析器,你只使用String對象(沒有char[]),它將會很慢,因為需要分配額外的空間。

虛函數調用增加。JVM中,幾乎所有的函數調用都是虛函數調用。有許多代碼嘗試避免虛函數調用,但是很多場景下,JVM無法解決這個問題。這阻礙了代碼的內聯,使代碼變慢。

缺乏高級的編譯特征及轉為匯編的能力。 如果你寫了一段能從匯編得益的代碼Java可能表現不佳。

在我看來,***的問題是垃圾回收。在程序中,強制在大的內存中進行多次完全GC,是最容易導致Java和C++之間產生鴻溝的原因之一。除此之外,如果將程序的工作集放在L2緩存之外,像大對象、缺乏內聯對象等問題,也會導致兩者之間的巨大差別。

低效的強制抽象和平臺函數也會導致速度下降,但是這通常只會因為低級的代碼才會產生。如果你使用寫得很好的Java代碼庫,這通常不是什么大問題。

答:Todd Lipcon

我基本同意Ben Maurer(hey Ben!)的回答。有幾個小點不同:

在***的JVM中,當這種分配永遠不會從(a)局部函數或(b)局部線程逃逸出去的時候,逃逸分析能有效地決定一種固定分配。也就是說當分配不需要 加鎖,通常是在自身的棧空間上進行的。這兩種情況下都是一種簡單的“指針碰撞(bump the pointer)”分配,這等同于C中的棧分配。

譯者注:

  • 逃逸分析 Escape Analysis,是一種編譯優化技術,指分析指針動態范圍的方法。通俗地說,當一個對象的指針被多個方法或線程引用時,我們稱這個指針發生了逃逸。
  • 指針碰撞(bump the point)。假設Java堆中內存是絕對規整的,所有用過的內存都被放在一邊,空閑的內存被放在另一邊,中間放著一個指針作為分界點的指示器,那所分配 內存就僅僅是把那個指針向空閑空間那邊挪動一段與對象大小相等的距離,這種分配方式稱為“指針碰撞”。

即使沒有逃逸分析,年青代的分配也是通過指針碰撞方式,在線程本地分配緩沖區(TLAB)中完成的,不需要進行同步。所以Java中小對象的分配有 的時候比C語言實現的 malloc() 方式更快。更好的 malloc 方法像Google的 tcmalloc,采用了類似的方式。但是由于C語言無法在內存中對分配后的對象重新分配,所以某些方面會受到限制。

雖然存在內聯和虛函數問題,但是實際上,Java在某些情況下甚至可以做的比C更好。特別是,C不能通過動態鏈接功能來實現內聯,因為內聯是在編譯 時期進行的,而不是運行時期。而Java可越過不同的類或庫的邊界來動態內聯一個函數,即使該類的真正實現在編譯期間還不可用。許多工作中,這種方式比 C++的虛函數調用更有效,C++虛函數調用總是需要調用虛表。而JIT編譯器,如果之前動態屬性已經丟失(如新的類已經被加載),能夠聰明地取消內聯優 化。

新版本的GCC提供一些這方面優化,稱為“全程序優化”或“鏈接時優化”(http://gcc.gnu.org/wiki/LinkTime…),允許在工程范圍內越過對象文件進行內聯。但是,基本上還是不允許通過動態鏈接的方式來實現內聯(如通過內聯的方式實現zlib的調用等)。許多大型項目都是通過復制標準庫的功能到它們的代碼中來實現。

原文鏈接: quora 翻譯: ImportNew.com - paddx
譯文鏈接: http://www.importnew.com/16218.html

 

責任編輯:王雪燕 來源: ImportNew
相關推薦

2015-06-01 06:39:18

JavaJava比C++

2020-11-18 09:26:52

@property裝飾器代碼

2023-11-23 23:52:06

options請求瀏覽器

2024-01-09 11:39:47

數字化轉型數字優先企業

2013-09-12 10:41:39

VDI部署

2023-05-18 08:38:13

Java鎖機制

2013-07-29 14:50:43

API

2022-07-20 08:07:21

數據庫分布式數據庫

2013-09-23 10:05:50

2010-07-13 16:07:26

SQL Server行

2014-11-03 09:52:25

DNSUDPTCP

2024-07-05 10:19:59

2022-09-05 10:01:19

VueReact

2009-03-05 10:55:00

企業無線Wi-Fi

2021-06-04 09:17:13

JavaScriptBoolean函數

2010-07-20 12:46:23

SQL Server聚

2025-05-26 08:15:00

Go開發指針

2021-09-14 07:26:25

雪花算法ID

2010-04-14 17:46:10

Oracle數據庫

2024-11-29 11:01:25

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 精品视频在线一区 | 亚洲va在线va天堂va狼色在线 | 色精品| 日韩精品1区2区3区 爱爱综合网 | 成人av一区 | 免费看国产一级特黄aaaa大片 | 午夜精品久久久久久久久久久久久 | 欧美福利| 日日夜夜免费精品视频 | 福利久久 | 欧美日韩专区 | 国产精品自拍视频网站 | 久久精品色欧美aⅴ一区二区 | 天天干人人 | 91综合网| 美女精品一区 | 久久久国产精品 | 久草免费在线视频 | 九九热这里只有精品在线观看 | 亚洲+变态+欧美+另类+精品 | 伊人网综合在线 | 国产午夜精品一区二区三区嫩草 | 久久午夜精品福利一区二区 | 久久51| 欧美日韩综合一区 | 性在线 | 久久久久国产一区二区三区四区 | 亚洲视频在线观看一区二区三区 | 久久久久久久久久性 | 国产一级电影在线 | 亚洲一区二区在线播放 | 九九久久久 | 91九色porny首页最多播放 | 一区二区三区四区免费观看 | 国产精品夜间视频香蕉 | 中文字幕一区二区三区四区五区 | 激情a| 国产精品一区二区无线 | 亚洲综合第一页 | 亚洲自拍偷拍免费视频 | 日韩欧美在线视频 |