改善Java应用程序性能的快速技巧
您可以相信仍然有人無知地在談?wù)摾占?#xff08;得到它嗎?)和JVM的性能。
……我將再次返回C語言,因此我不必?fù)?dān)心性能……
*嘆*
JVM一直在不斷改進(jìn)其收集器算法,并且每個(gè)發(fā)行版中都將高度復(fù)雜的優(yōu)化功能集成到了編譯器中(并且最近十年來一直在這樣做)。 您是否真的希望比世界上一些最聰明的人有經(jīng)驗(yàn),能力和時(shí)間來編寫更好,更優(yōu)化的C代碼?
Pleeeeease…
如果您像我一樣,其余99.99%的人,則明智的做法是忘記C??朔?(向所有核心C程序員致敬,不要被激怒)。
盡管我們的開發(fā)人員喜歡抽象,但我們不能否認(rèn)它們天生就是泄漏的事實(shí)。 硬件*確實(shí)*很重要。 處理器數(shù)量和內(nèi)存增長的趨勢使共享內(nèi)存線程并發(fā)變得更加困難。 鎖定 ,上下文切換和線程調(diào)度可以使您的吞吐量等于糖漿,認(rèn)為將更多線程倒入閃亮的新超級美容機(jī)中將以某種方式神奇地為您提供更多性能。 在某種程度上可能會,但這不是我的意思。
那么該怎么辦? 我并沒有聲稱自己是一名性能專家,但我不是,但我有一些實(shí)用建議,至少可以幫助我解決過去一些討厭的性能錯(cuò)誤。
1.編寫簡潔明了的代碼。 考慮使您的類不可變,它們是線程安全的,因此不需要同步,并且可以放心地對其進(jìn)行緩存,以確保對象值在創(chuàng)建后不會更改。 不變性還導(dǎo)致代碼更易于理解。 不要嘗試使用過早的優(yōu)化技巧來超越JVM。
Donald Knuth說: “程序員浪費(fèi)大量時(shí)間來考慮或擔(dān)心程序非關(guān)鍵部分的速度,而這些效率的嘗試實(shí)際上在考慮調(diào)試和維護(hù)時(shí)會產(chǎn)生嚴(yán)重的負(fù)面影響。 我們應(yīng)該忘記效率低下的問題,例如大約97%的時(shí)間:過早的優(yōu)化是萬惡之源。 但是我們不應(yīng)該放棄我們那關(guān)鍵的3%的機(jī)會?!?
2.花一些時(shí)間了解不同垃圾收集器的工作方式。 信息有點(diǎn)分散,但是它在那里。 找到垃圾回收和您的應(yīng)用程序之間的資源共享最有效點(diǎn)。 一般來說,較大的堆意味著垃圾收集器需要更努力地工作(竊取更多的CPU周期),并且暫停時(shí)間會更長,但頻率更低。 以我的經(jīng)驗(yàn),即使使用CMS也無法避免世界停頓,因?yàn)樽罱K您的堆將像瑞士奶酪一樣碎片化,并且繁榮, 內(nèi)存碎片化失敗 。 好消息是,JDK7可能會包括一個(gè)名為G1的新的低暫停時(shí)間收集器,該收集器有可能完全避免世界停頓。 另請參閱Java 7中的垃圾優(yōu)先收集器(G1) 。
3.在編程時(shí),默認(rèn)情況下始終使用java.util.concurrency 。 閱讀Java內(nèi)存模型和線程規(guī)范 。 它將幫助您理解為什么您的代碼可能無法正常運(yùn)行。 關(guān)于并發(fā)的主題也有很多不錯(cuò)的書:
- 實(shí)踐中的Java并發(fā)
- 多處理器編程的藝術(shù)
- Java并發(fā)編程:設(shè)計(jì)原理和模式(第二版)
4.您可能正在處理具有粗糙粒度同步的舊代碼(您無法影響),從而導(dǎo)致高線程爭用。 將CPU親和力與同一臺機(jī)器上的多個(gè)JVM進(jìn)程一起使用可以幫助減少對熱鎖的爭用。
5.如果您認(rèn)為通過執(zhí)行基準(zhǔn)測試發(fā)現(xiàn)JVM性能問題,請首先確保您“知道”測量結(jié)果是準(zhǔn)確的 。 如果您嘗試測量某些東西, 請不要測量其他東西 。 忽略此建議可能會使您誤以為是真正的問題所在。 因此,在開始測量之前,請確保正確隔離系統(tǒng)部件。
例如,如果您懷疑線程爭用,請查看ThreadInfo或嘗試jstat并查找sun.rt._sync_ContendedLockAttempts。
jstat -J-Djstat.showUnsupported=true -snap PID | grep _sync_關(guān)于這個(gè)主題有太多話要說,但是我現(xiàn)在沒有時(shí)間寫更多。 編碼愉快!
參考: Deep Hacks博客上的JCG合作伙伴 KristofferSj?gren的 Usain Bolt看起來 不錯(cuò) 。
相關(guān)文章 :
- Java最佳實(shí)踐
- 如何在Java中獲得類似于C的性能
- 每個(gè)程序員應(yīng)該了解的內(nèi)存系統(tǒng)知識
- Java內(nèi)存模型–快速概述和注意事項(xiàng)
翻譯自: https://www.javacodegeeks.com/2011/09/quick-tips-for-improving-java-apps.html
創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎(jiǎng)勵(lì)來咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎(jiǎng)總結(jié)
以上是生活随笔為你收集整理的改善Java应用程序性能的快速技巧的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 宁德时代:理想 MEGA 车型配备峰值
- 下一篇: C ++或Java,高频交易哪个更快?