引言 本文主要讲述JVM中几种常见的垃圾回收算法和相关的垃圾回收器,以及常见的和GC相关的性能调优参数. GC Roots 我们先来了解一下在Java中是如何判断一个对象的生死的,有些语言比如Python是采用引用计数来统计的,但是这种做法可能会遇见循环引用的问题,在Java以及C#等语言中是采用GC Roots来解决这个问题.如果一个对象和GC Roots之间没有链接,那么这个对象也可以被视作是一个可回收的对象. Java中可以被作为GC Roots中的对象有: 虚拟机栈中的引用的对象. 方法…
英文原文:Jeffrey Richter 编译:赵玉开 链接http://www.cnblogs.com/yukaizhao/archive/2011/11/25/dot_net_GC_2.html 上一篇文章介绍了.Net 垃圾回收的基本原理和垃圾回收执行Finalize方法的内部机制:这一篇我们看下弱引用对象,代,多线程垃圾回收,大对象处理以及和垃圾回收相关的性能计数器. 让我们从弱引用对象说起,弱引用对象可以减轻大对象带来的内存压力. 弱引用(Weak References) 当程序的根对…
HashMap简史 “Hash Code”这个概念第一次出现是在1953年1月的<Computing literature>中,H. P. Luhn  (1896-1964) 在一篇 IBM 的内部备忘录中提出了这个术语.当时 Luhn 是要解决这个问题:“给出组成一本教科书的一系列单词,要得出 100% 完整的(单词,出现页码集)对应关系,最好的算法和数据结构是什么?” H.P. Luhn (1896-1964) Luhn 写道, “hashcode” 是基本的运算符. Luhn 写道, “…
1.程序计数器 1. 什么是PC寄存器(程序计数器)? JVM中的程序计数寄存器(Program Counter Register)中,Register的命名源于CPU的寄存器,寄存器存储指令相关的现场信息.CPU只有把数据装载到寄存器才能够运行.JVM中的PC寄存器并不是广义上所指的物理寄存器,是对物理PC寄存器的一种抽象模拟. 它是一块很小的内存空间,几乎可以忽略不计.也是运行速度最快的存储区域. 在jvm规范中,每个线程都有它自己的程序计数器,是线程私有的,生命周期与线程的生命周期保持一致…
三个问题: 那些内存需要回收? -- 对象是否存活判断 什么时候回收?   --垃圾回收触发条件 如何回收? --垃圾回收算法 垃圾回收应用  -- 理解GC日志.使用垃圾回收命令和工具 1.  判断对象是否存活 引用计数法 可达性分析算法 引用计数法:给对象增添一个计数器,每当被引用一次,计数器数值+1:引用失效则-1:当计数器为0时,该对象不再被使用. 优点:实现简单,判定效率高. 缺点:不能解决对象之间相互循环引用问题. VM参数配置 -Xms100m -Xmx100m  -XX:+Pri…
我们都知道java语言与C语言最大的区别就是内存自动回收,那么JVM是怎么控制内存回收的,这篇文章将介绍JVM垃圾回收的几种算法,从而了解内存回收的基本原理. 一.stop the world 在介绍垃圾回收算法之前,我们需要先了解一个词“stop the world”,stop the world会在执行某一个垃圾回收算法的时候产生,JVM为了执行垃圾回收,会暂时java应用程序的执行,等垃圾回收完成后,再继续运行.如果你使用JMeter测试过java程序,你可能会发现在测试过程中,java程…
一.什么是JVM JVM是Java Virtual Machine(Java虚拟机)的缩写.JVM是一种用于计算设备的规范.它是一个虚构出来的计算机,是通过在实际的计算机上仿真模拟各种计算机功能来实现的. Java语言的一个很重要的特点就是与平台的无关性.而使用Java虚拟机是实现这一特点的关键. 一般的高级语言假设要在不同的平台上执行.至少须要编译成不同的目标代码. 而引入Java语言虚拟机后.Java语言在不同平台上执行时不须要又一次编译.Java语言使用Java虚拟机屏蔽了与详细平台相关的…
JVM内存分配策略 一:堆中优先分配Eden 大多数情况下,对象都在新生代的Eden区中分配内存.而新生代会频繁进行垃圾回收. 二:大对象直接进入老年代 需要大量连续空间的对象,如:长字符串.数组等,会直接在老年代分配内存.这是因为,这样可以避免在新生代区频繁的GC时发生大量的内存赋值(新生代的GC是采用复制算法的). 三:长期存活的对象“晋入”老年代 新生代中经历了多次GC仍然存活的对象.为了识别哪些对象应该放在新生代.哪些对象应该放在老年代,JVM给每个对象定义了一个对象年龄计数器.如果对象…
一.简单了解几个概念 1.什么是垃圾(Garbage)?什么是垃圾回收(Garbage Collection,简称 GC)? (1)什么是垃圾(Garbage)? 这里的垃圾 指的是 在程序运行过程中没有任何指针指向的对象,即不再被使用的对象. 如果不及时清理这些对象(垃圾),这些对象将会占用程序内存,无法被其他对象使用,严重时可能导致内存溢出. (2)什么是垃圾回收(Garbage Collection,简称 GC)? 一般程序占用的内存都是有限的,如果不断分配内存空间而不进行内存回收,内存迟…
1.JVM 基础知识点 JVM 虚拟机包含了:自动内存管理器.垃圾回收(垃圾回收调优). 执行顺序:Java 代码 --- .class 字节码文件(加载到虚拟机中) --- Java 类放在方法区中. 当执行一个 Java 方法时,Java 方法 --- 栈帧(Java 方法栈,存放局部变量/字节码的操作数栈.动态链接.方法出口等) --- 退出方法,弹出栈帧(无论方法是执行完还是遇到问题退出) JVM 虚拟机区域:共享区域 --- 堆.方法区,线程独享:Java 方法栈.本地方法栈.PC寄存…