jvm_20170206-java软件学习资料.docxVIP

  1. 1、本文档共10页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
jvm虚拟机 jvm虚拟机类似vmware等,只不过虚拟的机器在实际中不存在,只是软件环境。 目前jvm使用的是hotspot虚拟机(hotspot最初是一家小公司开发,后被sun收购) jvm执行class文件,除了java可以生产class外,jruby、groovy等语言也可以生成class让jvm执行。 内部以补码表示数据,因为这样做加法可以直接用补码相加,非常方便。 正数的补码是本身,负数的补码是按位取反加1. jvm启动流程 其中windows的jvm.cfg在 jvm.dll在 linux的jvm.cfg在 jvm结构 分为方法区、堆、栈等,此外在jvm外还可以直接在操作系统上分配内存,称为直接内存。jmm是java内存模型(java memory model) PC计数器(程序计数器、PC寄存器) 当前线程的执行的行号指示器。 每个线程拥有一个PC寄存器 在线程创建时创建 指向下一条指令的地址 执行本地方法(Native)时,它的值为undefined jvm中唯一一个不会产生OutOfMemoryError的区域。 方法区 保存装载的类信息,通常也叫永久区(Perm) 方法区是jvm的一个规范,是一个逻辑区,不同的虚拟机的实现不一样,hotspot是把方法区放到了堆的永久代中(jdk8以前),但在jdk8以后,永久代被移除,方法区放到了本地内存中(元空间),因此jdk8中的-XX:MaxPermSize已经失效了,取而代之的是-XX:MaxMetaspaceSize参数 1、存放类、方法、接口等描述信息 2、常量池:数据在编译期被确定,编译到了class文件,分为: 字面量:文本字符串、声明为final的常量值等; 符号引用:类和接口的完全限定名(Fully Qualified Name)、字段的名称和描述符(Descriptor)、方法的名称和描述符 3、运行时常量池: 方法区的一部分,所有线程共享。虚拟机加载Class后把常量池中的数据放入到运行时常量池。运行时常量池可以在程序运行的时候动态增加,比如Sern()方法,会将程序中的字符串放入运行时常量池。 JDK6时,String等常量信息置于方法区 JDK7时,已经移动到了堆 例如: 1、 /** * @Described:常量池内存溢出探究 * * 运行参数: -XX:PermSize=6M -XX:MaxPermSize=6M */ public class ConstantOutOfMemory { public static void main(String[] args) throws Exception { try { List<String> strings = new ArrayList<String>(); int i = 0; while (true) { strings.add(String.valueOf(i++).intern()); } } catch (Exception e) { e.printStackTrace(); throw e; } } } 其中String.valueOf(i++).intern()不断向常量池写数据,导致PermGen space异常 例2: import java.lang.reflect.Method; import junit.framework.TestCase; import xy.Enhancer; import xy.MethodInterceptor; import xy.MethodProxy; /** * @Described:方法区溢出测试 * 使用技术 CBlib * @VM args : -XX:PermSize=10M -XX:MaxPermSize=10M */ public class MethodAreaOutOfMemory { public static void main(String[] args) { while (true) { Enhancer enhancer = new Enhancer(); enhancer.setSuperclass(TestCase.class); enhancer.setUseCache(false); enhancer.setCallback(new MethodInterceptor() { @Override public Object intercept(Object arg0, Method arg1, Object[] arg2, Me

文档评论(0)

yjz0327 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档