Tony 发布的文章

深入JVM内核(七)


这里我们将对JVM中的堆进行详细分析。

内存溢出(OOM)的原因 在JVM中,内存区间包括:堆,永久区,线程栈和直接内存 1.而内存溢出的原因是占用大量堆空间,导致直接溢出,例如:

import java.util.ArrayList;
 public class Test {
    public static void main(String args[]){
        ArrayList<byte[]> list=new ArrayList<byte[]>();
        while(true){
            list.add(new byte[1024*1024]);
        }
    }
}

抛出异常:Exception in thread "main" java.lang.OutOfMemoryError: Java heap space

解决方法:可以手动设置增大堆空间,及时释放内存

再看一个例子:


java性能监视


我们在编程中难免要对java程序进行分析改进,为此,可以利用jdk自带的工具和命令进行分析: 1.jps

  • 列出java进程,类似于ps命令
  • 参数-q可以指定jps只输出进程ID ,不输出类的短名称
  • 参数-m可以用于输出传递给Java进程(主函数)的参数
  • 参数-l可以用于输出主函数的完整路径
  • 参数-v可以显示传递给JVM的参数


深入JVM内核(六)


今天来介绍JVM中的类装载器

首先简单介绍一下class类的装载验证流程:首先加载,然后链接,链接又包含(验证 ,准备,解析),然后再进行初始化。 下面具体介绍


JMeter使用入门


1.什么是Jmeter?我们看官网的解释

The Apache JMeter™ application is open source software, a 100% pure Java application designed to load test functional behavior and measure performance. It was originally designed for testing Web Applications but has since expanded to other test functions. 简单来说就是用来测试Web应用的开源程序 接着来看它的作用:


深入JVM内核(五)


下面我们继续对GC原理进行探究

1.串行收集器 1.png 是GC最最古老,最稳定的收集器,特点是效率高,但可能会产生较长的停顿 使用参数是-XX:+UseSerialGC(新生代、老年代使用串行回收;新生代复制算法;老年代标记-压缩算法)。