zoukankan      html  css  js  c++  java
  • 【文章阅读】Java虚拟机系列学习

    总目录:

    Java虚拟机 - 随笔分类 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/category/731395.html

    已读:

    1. Java虚拟机1:什么是Java - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4826691.html
      注:初步了解JAVA虚拟机,只是说明介绍,没有太多实际东西。

    2. Java虚拟机2:Java内存区域及对象 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4827590.html
      注:初步讲解了堆和栈的含义,以及内存说明。后面讲了对象创建时内存的分配,以及如何对象寻址,比价重要。

    3. Java虚拟机3:常用JVM命令参数 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4830692.html
      注:主要讲了常用JVM命令参数的含义。

    4. Java虚拟机4:内存溢出 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4833713.html
      注:主要讲了内存溢出:堆溢出、栈溢出,以及方法区和运行时常量池溢出,了解一下。

    5. Java虚拟机5:Java垃圾回收(GC)机制详解 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4836700.html
      注:介绍了垃圾回收算法,垃圾收集器,以及垃圾收集的实例代码讲解,还有如何观看GC日志。如果深入学习,那么这一块很需要好好看看。

    6. Java虚拟机6:内存溢出和内存泄露、并行和并发、Minor GC和Full GC、Client模式和Server模式的区别 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4839245.html
      注:主要介绍概念,标题中的。其他主要讲解Client模式和Server模式的区别:主要是不同模式下使用不同的JIT编译器。

    7. Java虚拟机7:内存分配原则 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4841177.html
      注:主要讲了内存分配原则,即新建对象优先分配在新生代还是老年代,如果新生代GC或者老年代FGC,内存是如何转移的,以及一些内存分配原则说明。

    8. Java虚拟机8:虚拟机性能监控与故障处理工具 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4842483.html
      注:主要讲了查询虚拟机一些基本信息的常用命令,有了这些命令我们才能获取到虚拟机具体的状态,才能发现问题,然后解决问题。
      另外,简单提了一些其他工具:JDK自带的,以及一些付费工具等。后续实际分析时可以参考。

    9. Java虚拟机9:Java类加载机制 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4844915.html
      注:类使用的7个阶段:加载(Loading)、验证(Verification)、准备(Preparation)、解析(Resolution)、初始化(Initiallization)、使用(Using)和卸载(Unloading)这7个阶段。
      每个阶段分别做了一些重要说明。不是很理解,不过可以先记着,后续需要再细看。

    10. Java虚拟机10:类加载器 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4845144.html
      注:主要介绍了类加载器,主要就是如何对类加载,是第九篇文章里加载部分的比较详细的讲解。
      不做笔记,后续有需要直接看原文。

    11. Java虚拟机11:运行期优化 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4857820.html
      注:这篇文章主要详细讲了运行期优化,即JIT即时编译相关,主要是如何确定需要进行即时编译:方法调用计数器和回边计数器;另外还有编译过程中的优化技术:公共子表达式消除,数组范围检查消除和方法内联以及逃逸分析。可以简单理解一下。

    12. Java虚拟机12:Java内存模型 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4859107.html
      注:这一章主要是讲了多线程相关,因为内存模型对多线程影响很大,主要想说明了两个内存:主内存和工作内存。以及两种内存之间的交互(原子性操作),以及一些交互规则。
      最后,顺带说了volatile关键字的作用和synchronized关键字的作用。
      还有先行发生happens-before原则:一共8个。线程之间的安全问题可以通过这八个原则来进行判断。

    13. Java虚拟机13:互斥同步、锁优化及synchronized和volatile - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/4978876.html
      注:互斥是因,同步是果;互斥是方法,同步是目的。
      另外主要从编译的字节码层次讲了:synchronized的实现和volatile的实现。

    14. Java虚拟机14:Java对象大小、对象内存布局及锁状态变化 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/6928133.html
      注:一个对象占多少字节,除了基本数据类型的字节数,还有不同操作系统保存对象元数据的内存。这些内容加起来,才是一个对象占用的全部字节。
      还讲了JAVA的四种锁的状态:无锁态、偏向锁、轻量级锁和重量级锁。详细介绍了每种锁的优点,以及在什么情况下,锁会由次一级升级为高一级的锁。

    15. Java虚拟机15:再谈四种引用状态 - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/7082471.html
      注:详细讲了JAVA的四种引用,通过实例讲解了在什么情况下,每种引用对应的对象会被回收。这才是最重要的。

    16. Java虚拟机16:Metaspace - 五月的仓颉 - 博客园 http://www.cnblogs.com/xrq730/p/8688203.html
      注:介绍lMetaspace相关想基础知识,但我不是很理解,也不知道学习这些有什么用,继续加油吧~~


    笔记:

    对于堆栈:

    • 堆是用来存放对象;
    • 而栈是用来执行程序的。

    垃圾回收机制:

    • 4种引用状态
      • 1、强引用
      • 2、软引用
      • 3、弱引用
      • 4、虚引用
    • 垃圾回收算法
      • 1、标记-清除(Mark-Sweep)算法
      • 2、复制(Copying)算法
      • 3、标记-整理(Mark-Compact)算法
    • 垃圾收集器
      • 1、Serial收集器
      • 新生代收集器(Client模式下:默认
      • 复制算法
      • 单线程
      • 2、ParNew收集器(Serial收集器的多线程版本)
      • 新生代收集器(Server模式下:首选)
      • 复制算法
      • 多线程
      • 3、Parallel收集器
      • 新生代收集器(Server模式下:默认
      • 复制算法
      • 多线程
      • 目标:达到一个可控制的吞吐量
      • 4、Serial Old收集器(Serial收集器的老年代版本)
      • 老年代收集器
      • 标记-整理算法
      • 单线程
      • 5、Parallel Old收集器(Parallel收集器的老年代版本)
      • 老年代收集器
      • 标记-整理算法
      • 多线程
      • 6、CMS收集器
      • 老年代收集器
      • 标记-清除算法
      • 线程?
      • 目标:获取最短回收停顿时间
      • 7、G1收集器
      • 好像忽略了新生代和老年代...跨时代

    收集器分类总结:

    主要是:Serial和Parallel
    Serial包含3个:新生代的单线程版本(Serial收集器)和多线程版本(ParNew收集器),以及老年代的单线程版本(Serial Old收集器)
    Parallel包含2个:新生代的多线程版本(Parallel收集器)和老年代的多线程版本(Parallel Old收集器)
    还有两个其他:CMS收集器和G1收集器

    垃圾收集器组合:
    Serial+Serial Old:Client模式下的默认垃圾收集器组合;
    Parallel+Serial Old:Server模式下的默认垃圾收集器组合;

    Java内存模型

    • 8个原子操作:
      • 主内存:
      • lock(锁定)
      • unlock(解锁)
      • read(读取)
      • write(写入)
      • 工作内存:
      • load(载入):与主内存交互
      • use(使用)
      • assign(赋值)
      • store(存储):与主内存交互
    • volatile型变量的特殊规则
      • volatile型变量的特性:
      • 1、保证此变量对所有线程的"可见性"。
        • 所谓"可见性"是指当一条线程修改了这个变量的值,新值对于其它线程来说都是可以立即得知的。
        • volatile只保证了可见性,并不保证基于volatile变量的运算在并罚下是安全的
      • 2、使用volatile变量的第二个语义是禁止指令重排序优化。
      • volatile型变量的规则:
      • 1、在工作内存中,每次使用某个变量的时候都必须线从主内存刷新最新的值,用于保证能看见其他线程对该变量所做的修改之后的值
      • 2、在工作内存中,每次修改完某个变量后都必须立刻同步回主内存中,用于保证其他线程能够看见自己对该变量所做的修改
      • 3、volatile修饰的变量不会被指令重排序优化,保证代码的执行顺序与程序顺序相同
  • 相关阅读:
    浏览器能正常访问的url,superagent不能正常访问
    Reactor模式理解
    牛客网剑指offer 二维数组的查找
    在C语言结构体中添加成员函数
    html页面字体相关
    html页面背景设定相关
    快速排序
    html页面边框的另一种写法
    2018暑期北航软件能力培养师资培训有感
    web.xml文件介绍
  • 原文地址:https://www.cnblogs.com/buwuliao/p/9098550.html
Copyright © 2011-2022 走看看