阅读更多

21顶
1踩

编程语言

转载新闻 推荐风轻扬:Java 6中的性能优化

2008-07-07 14:26 by 资深编辑 withyou 评论(5) 有12199人浏览
J2SE 6(代号:Mustang野马)主要设计原则之一就是提升J2SE的性能和扩展能力,主要通过最大程度提升运行效率,更好的垃圾收集和一些客户端性能来达到。

1、偏向锁(Biased locking)
Java 6以前加锁操作都会导致一次原子CAS(Compare-And-Set)操作,CAS操作是比较耗时的,即使这个锁上实际上没有冲突,只被一个线程拥有,也会带来较大开销。为解决这一问题,Java 6中引入偏向锁技术,即一个锁偏向于第一个加锁的线程,该线程后续加锁操作不需要同步。大概的实现如下:一个锁最初为NEUTRAL状态,当第一个线程加锁时,将该锁的状态修改为BIASED,并记录线程ID,当这一线程进行后续加锁操作时,若发现状态是BIASED并且线程ID是当前线程ID,则只设置一下加锁标志,不需要进行CAS操作。其它线程若要加这个锁,需要使用CAS操作将状态替换为REVOKE,并等待加锁标志清零,以后该锁的状态就变成 DEFAULT,常用旧的算法处理。这一功能可用-XX:-UseBiasedLocking命令禁止。

2、锁粗化(Lock coarsening)
如果一段代码经常性的加锁和解锁,在解锁与下次加锁之间又没干什么事情,则可以将多次加加锁解锁操作合并成一对。这一功能可用-XX:-EliminateLocks禁止。

3、自适应自旋(Adaptive spinning)
一般在多CPU的机器上加锁实现都会包含一个短期的自旋过程。自旋的次数不太好决定,自旋少了会导致线程被挂起和上下文切换增加,自旋多了耗CPU。为此Java 6中引入自适应自旋技术,即根据一个锁最近自旋加锁成功概率动态调整自旋次数。

4、常用大内存分布的堆(large page heap)
在大内分页是x86/amd64架构上用来减小TLB(虚拟地址到物理地址翻译缓存)大小的TLB失配率。Java 6中的内存堆可以使用这一技术。

5、提高数组拷贝性能
对每种类型大小写一个定制的汇编数组拷贝程序。

6、后台进行代码优化
Background Compilation in HotSpot™ Client Compiler: 后台进行代码优化

7、线性扫描寄存器分配算法(Linear Scan Register Allocation):
一种新的寄存器分配策略,基于SSA(static single assignment),性能提高10%左右。常用的寄存器分配算法将寄存器分配看作图着色问题,时间复杂度是O(n^4),不适用于Java的JIT编译。原来的JVM里是根据一些本地启发式规则来分配寄存器,效果不太好,Java 6中使用的线性扫描寄存器算法能够达到与图颜色算法相似的效果,并且时间复杂度是线性的。

8、并行缩并垃圾收集器(Parallel Compaction Collector)
进行Full GC时使用并行垃圾收集(JDK 5里原来非Full GC是并行的但Full GC是串行的),使用-XX:+UseParallelOldGC开启这一功能

9、并行低停顿垃圾收集器(Concurrent Low Pause Collector)
显式调用gc(如System.gc)时也可以并行进行标记-清扫式垃圾收集,使用-XX:+ExplicitGCInvokesConcurrent开启。

10、Ergonomics in the 6.0 Java Virtual Machine
自动调整垃圾收集策略、堆大小等配置,这一功能在JDK 5中加入,JDK 6中得到显著增强,SPECjbb2005性能提高70%。

11、boot类装载器的优化
jre中增加一个描述package所在jar文件的元索引文件,加快classloader加载类性能,提高桌面Java应用启动速度(+15%)。内存占用也减少了10%

12、图形程序优化
在jvm启动之前显示splash。

Swing程序中每个窗口有一个后台显示缓存,当该窗口原来被遮挡,现在要显示时直接从该缓存拷贝数据进行渲染,即使该窗口的绘制线程被阻塞也可以完成这一渲染.

21
1
评论 共 5 条 请登录后发表评论
5 楼 弃天笑 2010-09-21 09:55
学习一下,最近在研究
4 楼 flyfly98 2010-09-14 22:46
这些东西从来都没有见过,挺深的,值得我好好学习,谢谢啦
3 楼 leo_soul 2010-08-20 17:30
看了10行 看哭了
2 楼 AllenZhang 2008-07-08 13:39
看不懂没啥奇怪的。这个我感觉是jvm内部的开发技术手册。
有些实现不是针对java开发人员的。
还有其实一些所谓的名词,也是应该是起源于内部定义。
1 楼 jerry256 2008-07-08 11:42
好多都看不懂 呵呵 好高深呀 看来还得继续努力呀 呵呵

发表评论

您还没有登录,请您登录后再发表评论

相关推荐

  • sqlworm蠕虫 源程序

    一个蠕虫源程序,有想看的可以自己分析一下。

  • SQL worm sapphire 关键代码分析 (转)

    SQL worm sapphire 关键代码分析 (转)[@more@]突然间对它sql woRM sapphire的代码非常感兴趣,针对网上给出的test code(自己抓包也行), 一直读到临晨4点,终于把关键代码都注释起...

  • 【软件逆向-分析流程】关键代码定位、加密算法识别

    【软件逆向-分析】

  • SpringBoot源码分析------关键代码分析

    我们在之前已经了解SpringBoot源码分析------mvc容器的创建和tomcat的启动过了,SpringBoot的启动是通过内部new出对象,在进行run()方法的。 现在我们来了解一下run()方法中的每一个步骤。 SpringApplication.run() public ConfigurableApplicationContext run(String... args) { StopWatch stopWatch = new StopWatch(); stopWatch.start();

  • 苏睿暄Sql worm 2的源代码

    CODE:#include #include #include #include #include #include #include #include #include #define ServiceName "Microsoft NetWork Services FireWall";//欺骗对方char RemoteFilePath[128]={0};bool ConnIPC(char *Re

  • Blog13 图神经网络的模型级解释——关键代码分析5+大总结

    ​ 2021SC@SDUSC 本篇代码分析模块为:TrainGenerator.py 前面一篇博客中,我们分析了图生成器的定义过程,为了是模型达到更好的效果,我们下面来看一下作者是如何进行训练的。 一.训练图生成器 (1)一些初始化设置 ​

  • Blog11 图神经网络的模型级解释——关键代码分析3

    2021SC@SDUSC 本篇代码分析模块为:train.py

  • U-Boot关键代码分析

    U-Boot移植前要对源代码有一定了解,主要介绍U-Boot中一些难以理解代码分析

  • 查询关键代码解析

    5,查询关键代码解析 bindView ( ) ContactEntryListAdapter.java               疑惑1: 在bindView( )函数中,直接将itemView 直接转化为 ContactListItemView? 解答:在父类 CompositeCursorAdapter 的 getview 函数中,首先调用 newView() 然后才调用 bind

  • SSD关键源码解析

    SSD(SSD: Single Shot MultiBox Detector)是采用单个深度神经网络模型实现目标检测和识别的方法。如图0-1所示,该方法是综合了Faster R-CNN的anchor box和YOLO单个神经网络检测思路(YOLOv2也采用了类似的思路,详见YOLO升级版:YOLOv2和YOLO9000解析),既有Faster R-CNN的准确率又有YOLO的检测速度,可以

  • Blog12 图神经网络的模型级解释——关键代码分析4

    2021SC@SDUSC 本篇代码分析模块为:GraphGenerator.py 这篇代码文件是论文中设计的图生成器的定义过程。

  • Coursera Self Driving Car Part4 运动规划FinalProject原理及关键代码解析

    本博客针对Coursera上无人驾驶课程的第四章运动规划的课后大作业-设计一个运动规划器的源码进行解析。(2021.11.20未完待续) 相关链接: 课程作业运行效果视频链接 Project题目介绍 Course4FinalProject源码链接 Coursera课程视频链接 1.代码架构简述 在Coursera官网下载Part4运动规划的课后最终项目题目文件"Coursera4FinalProject"可以看到如下文件: 其中“behavioural_planner.py”,“c...

  • Blog10 图神经网络的模型级解释——关键代码分析2

    本篇分析代码模块为:model.py文件 在上一篇博客中,我们分析了加载数据集的文件,这篇文章,我们来对model.py文件进行分析。

  • 数据分析关键代码汇总

    # 头部引入 import pandas as pd import numpy as np import matplotlib.pyplot as plt %matplotlib inline import seaborn as sns import warnings warnings.filterwarnings("ignore") import missingno...

  • SQL slammer蠕虫王汇编代码详解

    文章目录简介SQL slammer分析汇编 简介 网络安全其实并不是我做的比较多的方向,所以对于病毒的研究也只是皮毛。不过这里公开一下对于SQLslammer的代码分析,其中借鉴了不少,并且自己也对汇编代码进行了更加清晰的解释,我相信即使你不熟悉汇编看了我的标注也可以明白程序逻辑。 甚至说不定你对汇编还变得更加熟练了。哈哈~~ SQL slammer Microsoft SQL Server 20...

  • kkFileView(七)关键代码分析(6)

    2021SC@SDUSC

  • kkFileView(二)关键代码分析(1)

    2021SC@SDUSC 此项目是由Springboot框架搭建,前端使用了freemaker生成页面。 (一) 首先我们分析了项目的目录结构 可以得到项目的前端代码在resources包中,static中存放着css,js,bootstrap等静态文件,web中存放ftl类型的freemaker文件。 java包中存放着项目的核心后端代码,其中FilePreviewApplication为启动项目的主程序。 @SpringBootApplication @Enabl...

Global site tag (gtag.js) - Google Analytics