垃圾回收你懂,Java垃圾回收你懂吗?
摘要:在用 C 之类的编程语言时,程序员需要自己手动分配和释放内存。而 Java 不一样,它有垃圾回收器,释放内存由回收器负责。本文接下来将介绍Java垃圾收集的知识原理。
java内存区域
Q: Java虚拟机规范将JVM虚拟机所管理的内存分为几部分?如果是多选题,估计会给一些不在里面的,例如直接内存。
A:程序计数器、java虚拟机栈、本地方法栈、方法区、堆。

java对象在内存上的分配:

§ GC策略
Q:java使用根搜索算法来确定对象是否存货,哪些对象可以作为GC Roots?
A:
- 虚拟机栈(栈帧中的本地变量表)中的引用的对象
- 方法区中的类静态属性引用的对象
- 方法区中的常量引用的对象
- 本地方法栈中JNI(Native方法)的引用对象
Q: 标记清除、标记整理、复制算法哪个块?
A: 复制算法较快。
3个算法含义如下:

Q: SerialOld用的是什么算法?
A: 标记整理算法,属于处理老年代算法。
各收集器的变化图如下,主要关注一下变化和区别,


Q: fullGC 会发生在老年代区还是新生代区?
A: 会发生在老年代区。 相反,minorGC一般发送在新生代区。
新生代、老生代以及minorGC、fullGC的发生流程如下:

Q: 方法区里的class对象(即类对象)什么时候会被回收?
A: 所有实例都被回收、对应classLoader也被回收、class对象不会再被引用或者反射(这个咋确定?当初书里看到的,没懂)
§ finalized与GC
Q: 什么时候会调用对象的finalized方法
A: JVM启动垃圾回收,且该对象要被回收时。
finalized应该更多是规范吧,很多规范里都要求我们不要自己实现finalized了,毕竟不确定性太大。
§ Java虚拟机GC参数配置
突然想起来当初看java虚拟机时,把那些参数给跳过了,感觉记不住。
但现在发现还是得学的,赶紧恶补一下。
Q:
-client和-server的对比
()启动较快
()性能和内存管理效率高(注意启动快和性能好不是一回事)
桌面应用一般使用(), 服务器一般使用()
A:
(-clien)启动较快
(-server)性能和内存管理效率高
桌面应用一般使用(-clien), 服务器一般使用(-server)
有4个跟内存相关的参数
-Xmn -Xms -Xmx -Xss
回答下面的问题:
Q:
用于配置java初始堆内存的是()
A:
-Xms。
-X、memory、size ,内存大小
Q:
用于配置java堆的最大值的是()
A:
-Xmx。
-X、memory、max
最大内存

Q:如果不设置,-Xms和-Xmx的大小分别默认是多少?
A:
不设置的话,二者相等,默认是 物理内存/64(小于1G)
Q:用于配置新生代内存大小的最大值是:()
你问我什么是新生代内存?
就是下面这个,1个E区加2个S区的这个内存大小
A:
-Xmn。
-X、memory、new
相类似的还有-XX:NewSize 和 -XX:MaxNewSize。
Q: 如何根据上面的参数计算老年代内存大小?
A:
Xmx的值(堆最大值)- Xmn的值(新生代内存)
Q: 用于配置线程栈内存的是()? 替代的还有哪个参数?
A:
-Xss。 另一个是-XX:ThreadStackSize
-Xss指 -X stack size
有下面3个和gc相关的参数
-Xnoclassgc -Xincgc -Xloggc:file
回答以下问题:
Q:
可用于关闭针对类对象的gc功能的是()
可用于减少gc的程序停顿时间的是()
用于输出gc相关日志的是()
A:
可用于关闭针对类对象的gc功能的是(-Xnoclassgc)
可用于减少gc的程序停顿时间的是(-Xincgc)
用于输出gc相关日志的是(-Xloggc:file)
Q:-verbose 一般是用于什么的?
A:
查询gc问题。
- -verbose:class 输出jvm载入类的相关信息,当jvm报告说找不到类或者类冲突时可此进行诊断。
- -verbose:gc 输出每次GC的相关情况,后面会有更详细的介绍。
- -verbose:jni 输出native方法调用的相关情况,一般用于诊断jni调用错误信息。
Q: -XX:PermSize和-XX:MaxPermSize设置的是什么内存?
A:
方法区的内存。就是最开始那个图里的这个

通过配置-XX:PermSize以及-XX:MaxPermSize来控制这块内存的大小,jvm在启动的时候会根据-XX:PermSize初始化分配一块连续的内存块,这样的话,如果-XX:PermSize设置过大,可能会很浪费。而Max如果设置小了,可能会omm。
Q:-XX:MetaspaceSize和-XX:MaxMetaspaceSize又是什么内存?
A:
元数据区内存。 java8引入的,用于替代上面的perm区。
无论-XX:MetaspaceSize和-XX:MaxMetaspaceSize两个参数如何设置,随着类加载越来越多不断扩容调整,直到MetaspaceSize(如果没有配置就是默认20.8m)触发FGC,上限是-XX:MaxMetaspaceSize,默认是几乎无穷大
本文分享自华为云社区《Java云服务开发知识学习之 java垃圾收集》,原文作者:breakDraw 。
垃圾回收你懂,Java垃圾回收你懂吗?的更多相关文章
- 【垃圾回收-CMS】Java内存回收实践经验 防止内存报警
jdk6和7服务器端(-server) 默认的新生代的垃圾回收器为:PS Scavenge,老年代默认的垃圾回收器为:PS MarkSweep 目前项目使用了jdk7,tomcat7,经常出现内存堆使 ...
- [译]Java垃圾回收是如何工作的
说明:这篇文章来翻译来自于Javapapers 的How Java Garbage Collection Works 这部分教程是为了理解Java垃圾回收的基础以及它是如何工作的.这是垃圾回收系列教程 ...
- [译]Java 垃圾回收介绍
说明:这篇文章来翻译来自于Javapapers 的Java Garbage Collection Introduction 在Java中,对象内存空间的分配与回收是由JVM中的垃圾回收进程自动完成的. ...
- Java内存回收机制
在Java中,它的内存管理包括两方面:内存分配(创建Java对象的时候)和内存回收,这两方面工作都是由JVM自动完成的,降低了Java程序员的学习难度,避免了像C/C++直接操作内存的危险.但是,也正 ...
- Java内存回收机制基础[转]
原文链接:http://blog.jobbole.com/37273/ 在Java中,它的内存管理包括两方面:内存分配(创建Java对象的时候)和内存回收,这两方面工作都是由JVM自动完成的,降低了J ...
- 【朝花夕拾】Android性能篇之(三)Java内存回收
在上一篇日志([朝花夕拾]Android性能篇之(二)Java内存分配)中有讲到,JVM内存由程序计数器.虚拟机栈.本地方法栈.GC堆,方法区五个部分组成.其中GC堆是一块多线程的共享区域,它存在的作 ...
- Java垃圾回收(整理)
Java垃圾回收 Garbage Collection:GC: 什么样的对象才是垃圾?怎样判断一个对象引用是不是垃圾? 垃圾回收算法:Mark-Sweep(标记-清除)算法,Copying(复制)算法 ...
- Java垃圾回收机制详解
前言 Java 相比 C/C++ 最显著的特点便是引入了自动垃圾回收 (下文统一用 GC 指代自动垃圾回收),它解决了 C/C++ 最令人头疼的内存管理问题,让程序员专注于程序本身,不用关心内存回收这 ...
- 【转载】Java垃圾回收机制
原文地址:http://www.importnew.com/19085.html Java垃圾回收机制 说到垃圾回收(Garbage Collection,GC),很多人就会自然而然地把它和Java联 ...
- 【转】深入理解 Java 垃圾回收机制
深入理解 Java 垃圾回收机制 一.垃圾回收机制的意义 Java语言中一个显著的特点就是引入了垃圾回收机制,使c++程序员最头疼的内存管理的问题迎刃而解,它使得Java程序员在编写程序的时候不再 ...
随机推荐
- 深入理解 Skywalking Agent
概述 Agent 功能介绍 + 整体结构 + 设计 插件机制详解 Trace Segment Span 详解 异步 Trace 详解 如何正确地编写插件并防止内存泄漏 扩展:如何基于 Skywalki ...
- 在 kubernetes 环境中实现 gRPC 负载均衡
前言 前段时间写过一篇 gRPC 的入门文章,在最后还留了一个坑没有填: 也就是 gRPC 的负载均衡问题,因为当时的业务请求量不算大,再加上公司没有对 Istio 这类服务网格比较熟悉的大牛,所以我 ...
- 16. 从零开始编写一个类nginx工具, 反向代理upstream源码实现
wmproxy wmproxy将用Rust实现http/https代理, socks5代理, 反向代理, 静态文件服务器,后续将实现websocket代理, 内外网穿透等, 会将实现过程分享出来, 感 ...
- 3种web会话管理的方式(session)
阅读目录 https://www.cnblogs.com/lyzg/p/6067766.html 1. 基于server端session的管理 2. cookie-based的管理方式 3. tok ...
- JUC并发编程学习笔记(十四)异步回调
异步回调 Future设计的初衷:对将来的某个事件的结果进行建模 在Future类的子类中可以找到CompletableFuture,在介绍中可以看到这是为非异步的请求使用一些异步的方法来处理 点进具 ...
- 一篇适合躺收藏夹的 Nexus3 搭建 NuGet&Docker 私有库的安装使用总结
前言 Nexus 是支持 Nuget.Docker.Npm 等多种包的仓库管理器,可用做私有包的存储分发,缓存官方包.本篇将手把手教学使用 Nexus 搭建自己的 NuGe t& Docker ...
- Linux TTY/PTS
转载:https://segmentfault.com/a/1190000009082089 当我们在键盘上敲下一个字母的时候,到底是怎么发送到相应的进程的呢?我们通过ps.who等命令看到的类似tt ...
- 玩转开源 | 搭建 Hugo 管理 Markdown 文档
在工作.学习中,不可避免会要写一些文档:又或者想搭建个简单网站,记录和分享您的生活经验或知识:撰写这些文档中使用 markdown 是一个非常不错的选择,让我们更加聚焦在文档表达的内容上.实际上笔者的 ...
- java把数据批量插入iotdb
package com.xlkh.kafka; import cn.hutool.core.collection.CollectionUtil; import com.alibaba.fastjson ...
- Spring Boot 3.2发布:大量Java 21的支持上线,改进可观测性
就在今天凌晨,Spring Boot 3.2正式发布了!该版本是在Java 21正式发布之后的重要支持版本,所以在该版本中包含大量对Java 21支持的优化. 下面,我们分别通过Spring官方发布的 ...