(4)java方法区

java方法区
【名词解析】
        --->和java堆一样,方法区是一块所有线程共享的内存区域。
        --->保存系统的类信息,比如,类的字段,方法,常量池等。
        --->方法区的大小决定了系统可以保存多少个类,如果系统定义了太多的类,导致方法区溢出,虚拟机同样会抛出内存溢出的错误
        --->jdk1.6和jdk1.7方法区可以理解为永久区。
        --->jdk1.8已经将方法区取消,替代的是元数据区。
        --->jdk1.8的元数据区可以使用参数-XX:MaxMetaspaceSzie设定大小,这是一块堆外的直接内存,与永久区不同,如果不指定大小,默认情况下,虚拟机会耗尽可用系统内存

【参数设定】
        --->jdk1.6和jdk1.7的永久区可以使用参数-XX:PermSize 和-XX:MaxPermSize指定
        --->-XX:PermSize =5m 默认启动大小为5M
        --->-XX:MaxPermSize=64m 最大大小为64M
【异常】
        --->
        --->jdk1.8元数据区内存溢出:java.lang.OutOfMemoryError:Metaspace

时间: 2024-10-10 05:44:54

(4)java方法区的相关文章

Java方法区和运行时常量池溢出问题分析(转)

运行时常量池是方法区的一部分,方法区用于存放Class的相关信息,如类名.访问修饰符.常量池.字段描述.方法描述等. String.intern()是一个native方法,它的作用是:如果字符串常量池中已经包含了一个等于此String对象的字符串,则返回代表池中这个字符串的String对象:否则,将此String对象包含的字符串添加到常量池中,并返回此String对象的引用. 在JDK1.6及之前版本中,由于常量池分配在永久代中(即方法区),我们可以通过-XX:PermSize和-XX:MaxP

java垃圾回收机制-java堆中方法区中的内容会被删除么

问题描述 java堆中方法区中的内容会被删除么 java有垃圾回收机制,会自动回收不使用的对象,问题一:那在堆中的方法区中存储的关于类的代码以及常量池等这些信息会, 在不使用这个类以后,这些信息是会被销毁么?怎样被销毁呢?是由GC回收么?问题二:栈中自动分配的存储的对象引用会被自动销毁么?代码运行之后销毁么? 解决方案 堆上没有什么方法区.代码放在代码区,函数的局部变量放在堆栈上.栈中自动分配的存储的对象引用会被自动销毁么,是的,在函数返回的时候销毁.

java内存管理(堆、栈、方法区)

java内存管理 简介 首先我们要了解我们为什么要学习java虚拟机的内存管理,不是java的gc垃圾回收机制都帮我们释放了内存了吗?但是在写程序的过程中却也往往因为不懂内存管理而造成了一些不容易察觉到的内存问题,并且在内存问题出现的时候,也不能很快的定位并解决.因此,了解并掌握Java的内存管理是我们必须要做的是事,也只有这样才能写出更好的程序,更好地优化程序的性能. 概述 Java虚拟机在执行Java程序的过程中会把它所管理的内存划分为若干不同的数据区域,这些区域都有各自的用途以及创建和销毁

java类变量的在方法区中分配的内存地址存在哪?

问题描述 例如:class Test {pulbic static int testStaticInt = 5;public Test() {}...}假如该类被加载后(虚拟机的加载的顺序:装载 , 连接, 初始化),当到达"连接"部分时需要为类变量teststatciInt分配内存空间并初始化默认值0,.我想请教大牛帮忙解释下当前teststatciInt内存的地址有谁保存?当有调用Test.teststatciInt时Test如何查到teststatciInt的内存地址? 问题补充

java虚拟机 jvm 方法区实战

和java堆一样,方法区是一块所有线程共享的内存区域,用于保存系统的类信息,类的信息有哪些呢.字段.方法.常量池.方法区也有一块内存区域所以方法区的内存大小,决定了系统可以包含多少个类,如果系统类太多,方法区内存不够肯定会导致方法区溢出,虚拟机同样会抛出内存溢出信息.(内存溢出后面相关文章给大家总结) jdk6和jdk7中,方法区可以理解为永久区(Perm).永久区可以使用参数-XX:PermSize和-XX:MaxPermSize制定.默认情况下-XX:MaxPermSize为64MB.如果你

java 堆 栈 方法区的简单分析

<一>  基础数据类型(Value type)直接在栈(stack)空间分配,方法的形式参数,直接在栈空间分配,当方法调用完成后从栈空间回收.引用数据类型,需要用new来创建,既在栈空间分配一个地址空间(reference),又在堆空间分配对象的类变量(object) .方法的引用参数,在栈空间分配一个地址空间,并指向堆空间的对象区,当方法调用完成后从栈空间回收.局部变量 new 出来时,在栈空间和堆空间中分配空间,当局部变量生命周期结束后,栈空间立刻被回收,堆空间区域等待GC回收. 方法调用

java-Java的内存模型之方法区

问题描述 Java的内存模型之方法区 这两天看Java的内存模型,越看越迷糊,到底Java文件里的方法区是如何存储的,又是如何管理的呢? 解决方案 方法,也就是函数的实现,应该是在代码区.但函数中肯定会用到内存,无论是静态分配的.还是动态分配的. 解决方案二: http://blog.csdn.net/lihaipeng0417/article/details/12653741 解决方案三: 方法,也就是函数的实现,应该是在代码区.但函数中肯定会用到内存,无论是静态分配的.还是动态分配的.htt

Java方法参数是引用调用还是值调用?_java

方法调用(call by) 是一个标准的计算机科学术语.方法调用根据参数传递的情况又分为值调用( call by reference ) 和引用调用( call by value ) .江湖上有很多关于这两种调用的定义 ,最通常的说法是传递值的是值调用,传递地址的是引用调用.这其实很不恰当,这种 这些说法很容易让我们联想到Java的对象参数传递是引用调用,实际上,Java的对象参数传递仍然是值调用 . 我们首先用一段代码来证实一下为什么Java的对象参数传递是值调用. public class

使用Annotation根据用户不同角色分配访问Java方法的权限

在 Web http://www.aliyun.com/zixun/aggregation/17799.html">开发过程中,一个非常理想的开发过程是,开发人员在开发中并不需要关心权限问题,不需要在 Java 方法中写很多逻辑判断去判断用户是否具有合适的角色和权限,这样开发会花费非常多的人力成本,因为所有的开发人员都需要了解关于权限的详细内容,也非常不容易进行后期维护.我们希望有专门的很少数量的开发人员了解权限内容,并且可以随时方便的修改和配置.于是,我们使用 Annotation,在