`
soartju
  • 浏览: 247376 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

[佳文共赏]从java内核看性能分析与设计

阅读更多

转自:http://blog.csdn.net/chief1985/archive/2008/03/21/2201392.aspx


引言  
java语言自90年代出现以来,因为它的安全性和跨平台性(即所谓的”Write Once,Run Anywhere”)等特点,深得广大程序员的青睐,但是同时,Java程序的运行效率的低下也是程序员的心病。Java是介于解释型和编译型之间的一种 语言,同样的程序,如果用编译型语言C来实现,其运行速度一般要比Java快一倍以上。怎样提高java应用程序的效率是广大程序员关心问题。本文将从与 Java字节码的运行过程中影响性能的相关因素的分析入手,然后,探讨一些在Java代码的设计过程中具体的有助于提高性能的策略。  

一、性能分析   
JVM运行时的负载主要集中在字节码的执行,内存管理,线 程管理和其他的操作几个方面。  

1.1 JVM的结构   
JVM中运行的 是Java字节码(Bytecode).class文件,这种class文件除了准确定义一个类或接口的表示外,还定义了一些与平台相关的诸如字节顺序的 详细信息。  
Java的数据类型分为primitive和reference,对于不同的数据类型的运算在JVM中的有不同的指令去执行,比如 iadd,ladd,fadd就是分别针对int,long,float的加法运算,当然,它们的执行效率也不一样, 运行时的数据区,在一个程序运行时,JVM都要为它定义不同的运行数据区,有些数据区在JVM启动时就创建好了,直到整个JVM退出时才释放掉,还有一些 数据区的是属于每个线程的,它的生命周期与线程相等。  

JVM中的逻辑结构有: 
PC(program counter)寄存器 ,每个线程有自己的PC(program counter)寄存器,当JVM执行的方法不是本地(Native)方法时,这里存放当前线程运行的指令的地址,如果是本地(Native) 的,PC(program counter)寄存器的值没有定义。  
JVM栈(stack) ,当创建线程时,每个线程都创建一个属于自己的栈, 用来存放frames(见下面),它存有本地变量,方法调用中的部分结果。  
堆(heap) ,JVM中所有线程共享这个堆,类的实例和数组 都是从堆中分配内存的,堆是在整个JVM启动时初始化的。  
方法区 (Method Area) ,线程间共享,它存放每个类中的运行时常数池(runtime constant pool),域值和方法数据,以及方法和类的构造函数的代码,其中包括用于类的特殊方法,实例初始化和接口类型的初始化,  
运行时常数池 (runtime constant pool) ,是每个类或接口的class文件中的常数池表在运行时的表示,它包括各种常数如编译时就知道的数字常量,还有运行时才能确定的方法和域的引 用,类似传统语言的符号表,  
本地(Native )方法栈(Stack) ,用来支持本地(Native)方法调用,这些方法用非Java的语言编写,需要传统的"C"栈。  
帧 (Frames) ,存放方法调用中的数据和部分结果及返回值,执行动态连接,分派例外,一个新的Frame在方法被调用时创建,方法调用正常或非正常完成 时销毁,Frame从每个线程创建的JVM的栈中分配内存,它属于每个线程,每个Frame有自己的本地变量组,自己的操作栈(Operand Stack)和指向当前方法的运行时常数池的引用,本地变量组和操作栈的大小在编译的时候就已经确定,在一个获得控制的线程中只有一个Frame是激活 的,这个Frame为当前Frame,它的方法为当前方法,方法所属的类为当前类,当这个方法又调用别的方法或结束时,这个当前Frame不再激活,一个 新的Frame被创建并成为当前Frame,直到当前方法调用完成后,这个Frame被释放并返回结果,前一个方法的Frame成为当前的 Frame。
本地变量 ,每个方法的Frame包含一组在方法中定义的本地变量,它们的大小在Java编译时就已确定。  
动态连接 (Dynamic Linking) ,每个Frame包含一个指向当前方法的运行时常数池的引用,它通过符号引用(symbolic references)访问变量和指向被引用的方法,动态连接(Dynamic Linking)在运行时将这些方法的符号引用转为具体的方法引用,并加载相应的类,它还将变量影射到当前运行时的变量的内存偏移上。  

1.2 字节码(Bytecode)的执行  
JVM动态地加载(Loads),连接 (Links)和初始化(Initializes)类和接口的字节码,加载(Loading)就是JVM发现具有某一特定名字的类或接口的二进制表示,并 从这个二进制表示在内存中创建出一个类或接口,连接(Linking)就是使一个类或接口与JVM的运行时状态很好的结合,以便执行它,一个类或接口的初 始化就是执行它的初始化方法。  

1.3 内存管理  
Java是一个面向 对象的语言,因此,在JVM的内存中大部分是对象,从上面的分析我们知道,对象的内存是从堆(heap)分配的,对象内存的回收是由自动内存管理系统(由 叫垃圾收集器-Garbage Collector)来完成的,编程人员是不用显式的释放内存的,垃圾收集器Garbage Collector通过记录指向对象的引用的数目来决定是否释放对象所占据的内存空间,当指向某个对象的引用数为零时,这个对象就可以释放了。  

1.4 线程管理   
Java是一个支持多线程的语言,因此线程的管理是JVM的一个主要工 作,每个线程都有自己的工作内存,线程间的共享变量是存放在整个JVM的主内存中的,线程间数据的同步通过lock来共享数据并保证数据的一致性,线程间 控制的转移通过对wait,notify等方法的调用来实现。  

二、性能设计   
通 过以上的分析,我们就以下几个方面提出一些有关性能设计的策略。  

2.1 对象的构造   
从 上面我们知道,Java对象的内存是自动管理的,因此,一般认为,程序员是不用担心内存的分配的,但这种想法是不完全正确的,java通过垃圾收集器 (Garbage Collector)来处理内存分配与释放的底层操作,程序员不用直接管理内存,这样防止了由于内存的错误操作导致的数据破坏(corruption), 但并不意味着程序员不用担心内存的使用,内存的使用不但会给系统带来很大的负担,比如,Java并不阻止程序占用过多的内存,当对象向堆所请求的内存不足 时,垃圾收集器(Garbage Collector)就会自动启动,释放那些引用数为零的对象所占用的内存,Java也不会自动释放无用的对象的引用,如果程序忘记释放指向对象的引用, 则程序运行时的内存随着时间的推移而增加,发生所谓内存泄漏(memory leaks),创建对象不但消耗CPU的时间和内存,同时,为释放对象内存JVM需不停地启动垃圾收集器(Garbage Collector),这也会消耗大量的CPU时间。  

策略:尽量避免在被经常调用的代码中创建对象。  
对于集合类 (collection),应尽量初始化它的大小,如果不初始化它的大小,JVM自动给它一个缺省的大小,当你的要求大于这个缺省的大小时,JVM就会重 新创建一个新的collection对象,原来的对象就释放掉,这样必然会增加JVM的负担。  
当一个类的多个实例在其本地的变量里访问一个特 定的对象时,最好将这个变量设计为静态(static)的,而不是每个实例中变量里都存放那个对象的引用。
分享到:
评论

相关推荐

    行业教育软件-学习软件-佳文习题软件 2.0.zip

    《佳文习题软件 2.0:提升行业教育与学习效率的专业工具》 在数字化时代,教育领域正经历着前所未有的变革,其中行业教育软件和学习软件扮演着至关重要的角色。佳文习题软件 2.0 正是这样一款专为提升行业教育和...

    佳文LRC歌词编辑器1.0

    佳文LRC歌词编辑器1.0是一款专为制作LRC歌词而设计的强大工具,旨在提升用户在创建、编辑和管理歌词文件时的效率。LRC格式是专门为音乐播放器和卡拉OK应用设计的一种同步歌词格式,它允许歌词与音乐旋律同步显示,为...

    漆佳文的成绩.py

    漆佳文的成绩.py

    欲写佳文觅亮点作文.doc

    【标题】和【描述】中的"欲写佳文觅亮点作文.doc"暗示了这是一个关于写作指导和优秀作文分析的文档。文档中提到的【标签】是"资料 范文",表明它提供了写作素材和范文示例。文档的主要内容包括了对三篇高三作文的...

    佳文科技网络通讯协议图屏幕保护程序

    佳文科技网络通讯协议图屏幕保护程序

    美图-龙佳文-Serverless 中的 Node.js 实践.pdf

    美图-龙佳文-Serverless 中的 Node.js 实践

    基于AutoCAD和PDM的船舶总图数字化设计方法研究.pdf

    在当前的船舶设计与制造行业中,数字化设计已成为提高设计效率和准确性的重要手段。本研究介绍了基于AutoCAD和产品数据管理(PDM)系统相结合的船舶总图数字化设计方法。这种方法旨在解决传统船舶设计过程中存在的...

    片机原理与应用课程设计功能要求

    【单片机原理与应用课程设计】是一门实践性极强的课程,旨在让学生通过实际操作,掌握单片机的应用技巧、编程方法以及系统设计流程。设计任务要求学生在1.5周内完成一个单片机应用系统的编程设计,并提交设计报告,...

    佳文知识管理软件(打造自己的MSDN)

    2、支持多种编程语言的高亮显示:Delphi、Java、C++、C#、SQL等。高亮显示方式可以设定。 3、支持知识全文搜索功能。可以搜索到网页、文本、表格、树中的信息。 4、支持导入导出功能,可以实现知识交流和共享。 5...

    红领巾广播站实施方案设计.doc

    3. 佳文共赏:展示学生的创作才华,分享个人情感和观察。 4. 开心一刻:提供轻松幽默的内容,调节校园氛围。 5. 哆来咪点歌台:允许学生点歌,增进校园文化的互动性。 通过这样的实施方案,红领巾广播站将成为一个...

    基于AT89C51单片机的音乐播放器课程设计.doc

    二、元器件清单及简介 89C51单片机 本设计使用的是ATMEL公司生产的AT89C51高性能8位单片机,片内含8Kbytes的可反复擦 写的只读程序存储器和256bytes的随机存取数据存储器,器件采用ATMEL公司的高密度, 非易失性...

    妙用古诗,巧铸佳文作文课件.ppt

    6. 生命主题的诗词表达:用古诗词来描绘生命的不同面貌,如献身精神、浩然正气、超脱与豁达、无奈与感伤,展现出诗词在表达深刻主题时的力量。 7. 乐观精神的诗词象征:借用诗词中的意象来阐述乐观的态度,如“阳光...

    班组长培训的学习总结佳文汇总.doc

    6. **培训的重要性**:企业对班组长的培训是一个持续的过程,需要从需求调查、目标设定、方案制定、培训管理到效果评估等多个环节进行系统性考虑,以提升班组长的综合能力,适应企业的发展需求。 7. **培训资源的...

    佳文LRC歌词编辑器 V1.0.rar

    制作LRC的高效的工具。是速配歌词独立自主开发的Lrc歌词编辑器,该软件吸收了各Lrc歌词编辑器的优点,同时开发更多新功能,让老用户感觉更亲切,让新用户更容易上手。    软件截图一 ... 软件截图二

    P27N11-谢佳文-第五周.py

    1. 读取给定文本文件,统计单词,计算TOP 10 有一个文件sample.txt,对其进行单词统计,不区分大小写,并显示单词重复最多的10个单词。 2. 复制目录 选择一个已存在的目录作为当前工作目录,在其下创建a/b/c/d...

    小学红领巾广播站开播语.doc

    - 《佳文共赏》:分享优美的文章,激发学生的阅读兴趣和文学欣赏能力,培养审美情趣。 - 《故事驿站》:通过讲述各种故事,启迪智慧,激发想象力,让孩子们在故事中学到人生道理。 - 《校园直通车》:报道校园...

    最全校园之声广播站开场白.doc

    2. **文学欣赏**:“佳文共赏”栏目鼓励师生们品味文学之美,通过聆听和分享,提升文学素养,强调了文学在生活中的重要性,以及它对个人情感和思想的熏陶作用。 3. **情感表达**:广播站的主持人们用诗意的语言引导...

Global site tag (gtag.js) - Google Analytics