以下操作中,可能的解决java内存泄露问题的手段有:【多选】( )
- 在程序中调用System.gc();
- 关掉不再使用的网络/数据库连接;
- 在程序中调用finalize();
- 清理集合类中的无用对象;
- 在程序中调用Runtime.getRuntime().runFinalization();
答案应该为BD
首先内存泄露是由于某些无用对象无法回收,对象回收的条件是根据搜素算法不可达,那么哪些可以作为根呢?1.方法区中类静态变量引用的对象2.虚拟机栈帧中引用的对象3.本地方法栈帧中引用的对象4.方法区中常量引用的对象从这些根出发不可达的对象就是要回收的对象,答案是A和E都是jvm进行垃圾回收,不能从根本上解决内存泄露,答案c只是在垃圾回收前做一些操作而已(而且不保证会被执行完)而已.
下面哪种情况会导致持久区jvm堆内存溢出()
- 循环上万次的字符串处理
- 在一段代码内申请上百M甚至上G的内存
- 使用CGLib技术直接操作字节码运行,生成大量的动态类
- 不断创建对象
Permanent:持久代 (方法区)
装载Class信息、常量、静态变量、即时编译器编译后的代码等基础数据,默认64M,如果是类很多很多的服务程序,需要加大其设置 -XX:MaxPermSize=,否则它满了之后会引起fullgc()或Out of Memory。 注意Spring,Hibernate这类喜欢AOP动态生成类的框架需要更多的持久代内存。一般情况下,持久代是不会进行GC的,除非通过 -XX:+CMSClassUnloadingEnabled -XX:+CMSPermGenSweepingEnabled进行强制设置。