关于JVM的几道面试题

之前看编程之美,看到了对操作系统精通的定义,比如,写个程序能到任务管理器的CPU曲线划出一段正弦曲线,这种实际的动手能力确实值得我们去关注。

刚刚在看书,关于虚拟机规则的,突然想到可以出如下面试题:

  1. 给出一段会产生堆内存溢出的代码;
  2. 给出一段虚拟机栈和本地方法栈溢出的代码:分StackOverflowError和OutOfMemoryError给出程序;
  3. 给出一段能使运行时常量池溢出的代码;
  4. 给出一段能使方法区溢出的代码。

这些题目不仅考察了对Java内存分配的理解,更从实际操作上去处理内存的问题。理解好了这一类题目,有利于异常的纠错和系统的调优。

关于JVM的几道面试题_第1张图片


华丽的分割线----------------------------------------------------------------------

下面给出一些思路,其实主要还是给出第二题的思路.

  1. 堆溢出:堆里放的是new出来的对象,所以这部分很简单不断的new对象就可以了,但是为了防止对象new出来之后被GC,所以把对象new出来的对象放到一个List中去即可。为了有更好的效果,可以在运行前,调整堆的参数。
  2. 针对HotSpot虚拟机中的栈溢出,如果请求的栈深度大于虚拟机所允许的最大深度,抛出StackOverflowError,如果虚拟机在扩展时无法申请到足够空间则抛出OutOfMemoryError的异常。容易想到在单线程的堆中我们不断的让一个成员变量自增,容纳这个变量的单元无法承受这个变量了,就抛出StackOverflowError了。这就是一个 请求的栈深度大于虚拟机所允许的最大深度。还有种情况,可以开尽量多的线程,并在每个线程里调用native的方法,就自然会抛出 OutOfMemoryError了
  3. 运行时常量池溢出:运行时常量池是在方法区中的一部分,主要保存Class文件中描述的符号引用。可采用String类的intern方法。
  4. 方法区存放类的信息、常量、静态变量。这部分的溢出可采用增强Class加载的方式。


你可能感兴趣的:(java,jvm,内存)