• JVM内存结构——堆、栈、方法区、直接内存


    一、定义 

    1、堆:FIFO队列优先,先进先出。jvm只有一个堆区被所有线程所共享!堆存放在二级缓存中,调用对象的速度相对慢一些,生命周期由虚拟机的垃圾回收机制定。

    2、栈:FILO先进后出,暂存数据的地方。每个线程都包含一个栈区!栈存放在一级缓存中,存取速度较快,“栈是限定仅在表头进行插入和删除操作的线性表”。

    3、方法区:用来存放方法和static变量。

    二、存储的数据类型

    1、堆用来存储new出来的对象和数组

    2、栈用来存储基本类型变量和对象的引用变量的地址

    3、方法区存储方法和static变量

    三、优缺点

    1、堆的优点-可以动态的分配内存大小,生命周期不确定。缺点-速度略慢

    2、栈的优点-速度快,缺点-存在栈中的数据大小和生命周期必须是明确的,缺少灵活性。

     

     四、直接内存

    直接内存并不是虚拟机运行时数据区的一部分,也不是Java 虚拟机规范中农定义的内存区域。在JDK1.4 中新加入了NIO(New Input/Output)类,引入了一种基于通道(Channel)与缓冲区(Buffer)的I/O 方式,它可以使用native 函数库直接分配堆外内存,然后通脱一个存储在Java堆中的DirectByteBuffer 对象作为这块内存的引用进行操作。这样能在一些场景中显著提高性能,因为避免了在Java堆和Native堆中来回复制数据。

    本机直接内存的分配不会受到Java 堆大小的限制,受到本机总内存大小限制

    配置虚拟机参数时,不要忽略直接内存 防止出现OutOfMemoryError异常

    直接内存(堆外内存)与堆内存比较

    直接内存申请空间耗费更高的性能,当频繁申请到一定量时尤为明显
    直接内存IO读写的性能要优于普通的堆内存,在多次读写操作的情况下差异明显
    ————————————————
    版权声明:本文为CSDN博主「东桥小草」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    原文链接:https://blog.csdn.net/qq_31997407/java/article/details/79675371

  • 相关阅读:
    linux常用命令
    webStorm关闭自动保存
    jquery封装常用的方法
    请求头的设置
    表单序列化对象,jquery
    linux开机启动Tomcat服务器
    centOS安装git,保存用户名和密码
    CentOS7启动Tomcat报错:./startup.sh: Permission denied
    javaWeb使用百度编辑器上传图片的问题
    es6-Symbol用法
  • 原文地址:https://www.cnblogs.com/huhewei/p/12907645.html
Copyright © 2020-2023  润新知