Java内存管理

来源:互联网 发布:女生喜欢什么礼物知乎 编辑:程序博客网 时间:2024/05/16 18:42
1、GC线程是否为守护线程?
解析:线程分为守护线程和非守护线程(用户线程);只要当前JVM实例中尚存在任何一个非守护线程还没结束,守护线程就全部工作;只有当最后一个非护守线程结束时,守护线程随着JVM一同结束工作;守护线程最为典型的应用就是GC(垃圾回收器)。
2、解释内存中的栈(Stack)、堆(Heap)和静态存储区的用法?
解析:通常我们定义一个基本数据类型的变量、一个对象的引用、还有就是函数调用的现场保存都使用内存中的栈空间;通过new关键字和构造器创建的对象放在堆空间;程序中的字面量和常量都是存放在静态存储区中;栈空间操作快但很小,通常大量的对象都是存放在堆空间中,整个内存包括硬盘上的虚拟内存都可以被当成堆空间来使用。
String str = new String("Hello")
str存放在栈上,new出来的字符串对象放在堆上,"Hello"字面量放在静态存储区。
3、Java中会存在内存泄漏吗?
Java具有垃圾回收机制,理论上不存在内存泄漏问题。然而在实际开发中可能会存在无用但可达的对象,这些对象不能被GC回收也会发生内存泄漏。例如Hibernate的Session中的对象属于持久态,垃圾回收器不回收这类对象,这类对象却可能存在无用的垃圾对象。
4、GC是什么?为什么要有GC?
GC是垃圾收集的意思;内存管理是编程人员容易出现问题的地方,Java程序员不用担心内存管理,垃圾收集器会自动进行管理。垃圾回收器通常作为一个单独的低优先级的线程运行,不可预知的情况下对内存堆中已经死亡的或者长时间没有使用的对象进行清除和回收,程序员不能实时的调用垃圾回收器对某个对象或所有对象进行垃圾回收。
6、描述下JVM加载class文件的原理机制?
解析:JVM中类的装载是由类加载器(ClassLoader)和它的子类实现的,Java中的类加载器是一个重要的Java运行时系统组件,它负责在运行时查找和装入类文件中的类。
由于Java的跨平台性,经过编译的Java源程序并不是一个可执行的程序,而是一个或多个类文件。当Java程序需要使用某个类时,JVM会确保这个类已经被加载、连接和初始化。类的加载是指把类的.class文件中的数据读入到内存中,通常是创建一个字节数组读入.class文件,然后产生与所加载类对应的Class对象。加载完成后,Class对象还不完整,暂时还不能用。当类加载后就进入连接阶段,这一阶段包括验证、准备(为静态变量分配内存并设置默认的初始值)和解析(将符号引用替换为直接引用)三个步骤。最后JVM对类进行初始化,包括:如果类存在直接的父类并且这个类还没有被初始化,那么就先初始化父类;如果类中存在初始化语句,就依次执行这些初始化语句。
类加载是由类加载器完成的,类加载器包括:根加载器(BootStrap)、扩展加载器(Extension)、系统加载器(System)和用户自定义类加载器(java.lang.ClassLoader的子类)。类加载过程采用了父亲委托机制,更好的保证了Java平台的安全性,该机制中,JVM自带的Bootstrap是根加载器,其他的加载器都有且仅有一个父类加载器。类的加载首先请求父类加载器加载,父类加载器无能为力时才由其子加载器自行加载。JVM不会向Java程序提供对Bootstrap的引用。
Bootstrap:一般用本地代码实现,负责加载JVM基础核心类库 (rt.jar)
Extension:从java.ext.dirs系统属性所指定的目录中加载类库,父加载器为Bootstrap
System:应用类加载器,其父类是Extension。它从环境变量classpath或者系统属性java.class.path所指定的目录中记载类,是用户自定义加载器的默认父加载器。

原创粉丝点击