欢迎访问昆山宝鼎软件有限公司网站! 设为首页 | 网站地图 | XML | RSS订阅 | 宝鼎邮箱 | 后台管理


新闻资讯

MENU

软件开发知识

CMS(Current Mark Sweep)收集器是一 次  来源:宝鼎软件 时间:2018-07-31

原文出处: 老码农

1、你知道哪些可能你们线上使⽤什么GC计策?它有什么优势,适⽤于什么场景?

参考 触发JVM举办Full GC的环境及应对计策。

2、Java类加载器包罗⼏种?它们之间的⽗⼦干系是怎么样的?双亲委派机制是什么意思?有什么长处?

启动Bootstrap类加载、扩展Extension类加载、系统System类加载。

父子干系如下:

  • 启动类加载器 ,由C++ 实现,没有父类;
  • 扩展类加载器,由Java语言实现,父类加载器为null;
  • 系统类加载器,由Java语言实现,父类加载器为扩展类加载器;
  • 自界说类加载器,父类加载器必定为AppClassLoader。
  • 双亲委派机制:类加载器收到类加载请求,本身不加载,向上委托给父类加载,父类加载不了,再本身加载。
    优势制止Java焦点API改动。具体查察:深入领略Java类加载器(ClassLoader)

    3、如何⾃界说⼀个类加载器?你使⽤过哪些可能你在什么场景下需要⼀个⾃界说的类加载器吗?

    自界说类加载的意义:

    1. 加载特定路径的class文件
    2. 加载一个加密的网络class文件
    3. 热陈设加载class文件

    4、堆内存配置的参数是什么?

  • -Xmx 配置堆的最大空间巨细
  • -Xms 配置堆的最小空间巨细
  • 5、Perm Space中生存什么数据?会引起OutOfMemory吗?

    加载class文件。

    会引起,呈现异常可以配置 -XX:PermSize 的巨细。JDK 1.8后,字符串常量不存放在永久带,而是在堆内存中,JDK8今后没有永久代观念,而是用元空间替代,元空间不存在虚拟机中,二是利用当地内存。

    具体查察Java8内存模子—永久代(PermGen)和元空间(Metaspace)

    6、做GC时,⼀个工具在内存各个Space中被移动的顺序是什么?

    标志排除法,复制算法,标志整理、分代算法。

    新生代一般回收复制算法 GC,昆山软件公司,暮年月利用标志整理算法。
    垃圾收集器:串行新生代收集器、串行老生代收集器、并行新生代收集器、并行暮年月收集器。
    CMS(Current Mark Sweep)收集器是一种以获取最短接纳停即刻间为方针的收集器,它是一种并发收集器,回收的是Mark-Sweep算法。

    详见 Java GC机制。

    7、你有没有碰着过OutOfMemory问题?你是怎么来处理惩罚这个问题的?处理惩罚 进程中有哪些收获?

    permgen space、heap space 错误。

    常见的原因

  • 内存加载的数据量太大:一次性从数据库取太大都据;
  • 荟萃类中有对工具的引用,昆山软件开发,利用后未清空,GC不能举办接纳;
  • 代码中存在轮回发生过多的反复工具;
  • 启动参数堆内存值小。
  • 详见 Java 内存溢出(java.lang.OutOfMemoryError)的常见环境和处理惩罚方法总结。

    8、JDK 1.8之后Perm Space有哪些变换? MetaSpace⼤⼩默认是⽆限的么? 照旧你们会通过什么⽅式来指定⼤⼩?

    JDK 1.8后用元空间替代了 Perm Space;字符串常量存放到堆内存中。

    MetaSpace巨细默认没有限制,一般按照系统内存的巨细。JVM会动态改变此值。

  • -XX:MetaspaceSize:分派给类元数据空间(以字节计)的初始巨细(Oracle逻辑存储上的初始高水位,the initial high-water-mark)。此值为预计值,MetaspaceSize的值配置的过大会耽误垃圾接纳时间。垃圾接纳事后,引起下一次垃圾接纳的类元数据空间的巨细大概会变大。
  • -XX:MaxMetaspaceSize:分派给类元数据空间的最大值,高出此值就会触发Full GC,昆山软件开发,此值默认没有限制,但应取决于系统内存的巨细。JVM会动态地改变此值。
  • 9、jstack 是⼲什么的? jstat 呢?假如线上措施周期性地呈现卡顿,你猜疑可 能是 GC 导致的,你会怎么来排查这个问题?线程⽇志⼀般你会看个中的什么 部门?

    jstack 用来查询 Java 历程的仓库信息。

    jvisualvm 监控内存泄露,跟踪垃圾接纳、执行时内存、cpu阐明、线程阐明。

    详见Java jvisualvm扼要说明,可参考 线上FullGC频繁的排查。

    10、StackOverflow异常有没有碰着过?⼀般你揣摩会在什么环境下被触发?如何指定⼀个线程的仓库⼤⼩?⼀般你们写几多?

    栈内存溢出,一般由栈内存的局部变量过爆了,导致内存溢出。呈此刻递归要领,参数个数过多,递归过深,递归没有出口。

    谜底如有不正确,还请列位指正。