当前位置: 首页 > article >正文

java中的内存分配

目录

1.堆内存

2.栈内存

3.常量池

4.寄存器

5.示例

6.总结


1.堆内存

堆用来存放程序中动态生产的数据,如new出来的对象。

通过new方式创建的对象,数组及字符串都有自己的内存地址。

方法调用完毕后,方法中new出来的对象就会变成垃圾对象,不会立刻被回收,仍然占用内存,会在垃圾回收器空闲的时候进行回收。这也是java比较占内存的原因

创建出来的对象只包含各自的成员变量,并不包含方法。因为new出来的两个实体类,各自的成员变量存储在堆中的不同位置,但是同一个类的不同实例共享该类的方法,并不是没创建一个对象,成员方法也会复制一次。

2.栈内存

栈中主要存放一些基础数据类型的变量和引用对象的引用变量。

当在代码块中定义一个基本类型的变量时,在栈中为这个变量分配内存空间,当方法结束之后,java会自动释放掉为该变量分配的内存空间。

3.常量池

常量池中存放字符串常量及基本类型的常量,通过final进行定义。

常量池的好处是为了避免频繁的创建和销毁对象而影响性能,实现了对象的共享。

节省了内存空间,常量池中所有相同的字符串常量被合并,只占用一个空间。

4.寄存器

JVM内部虚拟寄存器,存取速度非常快,程序不可控制。

5.示例

        String a = "12";
        String b = "12";
        System.out.println(a == b);  // true

上述方法创建的字符串,在内存中其实只存在一个对象而已。这种写法有利于节省内存空间,同时还可以提高程序的运行速度,因为JVM会自动根据栈中数据的实际情况来决定是否创建新对象。

        String str1 = new String("abc");
        System.out.println(System.identityHashCode(str1));
        String str2 = new String("abc");
        System.out.println(System.identityHashCode(str2));
        System.out.println(str1 == str2);  // false

使用new来创建的对象,存在堆中。每调用一次就创建一个新的对象。创建的两个字符串虽然内容时一样的,但是地址不一样。

6.总结

在开发中,我们需要注意内存放的使用情况,避免出现内存溢出的问题,尤其是数据量大的情况下。


http://www.kler.cn/a/107521.html

相关文章:

  • npm list @types/node 命令用于列出当前项目中 @types/node 包及其依赖关系
  • 基于碎纸片的拼接复原算法及MATLAB实现
  • Spring Boot 2.x 和 Druid 多数据源整合 dm
  • 使用etl工具kettle的日常踩坑梳理之二、从Hadoop中导出数据
  • Elastic Observability 8.16:增强的 OpenTelemetry 支持、高级日志分析和简化的入门流程
  • 【STM32F1】——无线收发模块RF200与串口通信
  • 平方根倒数快速算法
  • 源码角度分析Java 循环中删除数据为什么会报异常
  • PHP与mysql数据库交互
  • 常用字符串函数拓展
  • 在本地模拟C/S,Socket套接字的使用
  • 【原创】解决Kotlin无法使用@Slf4j注解的问题
  • 设计模式(13)适配器模式
  • GZ035 5G组网与运维赛题第4套
  • 【Android】一个contentResolver引起的内存泄漏问题分析
  • 通信基础(一):数据传输基础
  • Java工具库——Commons IO的50个常用方法
  • 软考系统架构之案例篇(软件工程相关概念)
  • .net 7 上传文件踩坑
  • 【Python机器学习】零基础掌握DecisionBoundaryDisplay检验、检查
  • SpringMVC Day 05 : Spring 中的 Model
  • react实现步进器
  • flutter升级+生成drift文件
  • hadoop使用简介
  • C# 递归算法使用简介_常用整理
  • Vue引入异步组件