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

Java中堆栈

文章目录

  • Java中堆栈
    • 1. 栈(Stack)
      • 特点
      • 示例
    • 2. 堆(Heap)
      • 特点
      • 示例
    • 3. 核心区别
    • 4. 常见问题
    • 5. 内存可视化示例
      • 内存布局示意图:
    • 总结

Java中堆栈

在 Java 中,“堆栈” 通常指的是堆(Heap)**和**栈(Stack),它们是内存中的两个重要区域,用于存储不同类型的数据。以下是它们的核心概念和区别:

1. 栈(Stack)

特点

  • 线程私有:每个线程都有自己的栈,随线程创建而分配,线程结束时销毁。
  • 后进先出(LIFO):方法调用时,会在栈中创建栈帧(Stack Frame),方法执行完毕后栈帧弹出。
  • 存储内容:
    • 局部变量:方法内定义的基本数据类型(如intboolean)和引用变量(对象的内存地址)。
    • 方法调用信息:包括返回地址、参数值等。
  • 内存管理:由 JVM 自动管理,速度快,空间连续。
  • 异常:如果栈深度超过限制(如递归过深),会抛出StackOverflowError

示例

public class StackExample {public static void main(String[] args) {int a = 10;             // 基本类型变量a存储在栈中Object obj = new Object(); // 引用变量obj存储在栈中,指向堆中的Object实例method(obj, a);        // 方法调用时,参数值压入栈}private static void method(Object param, int value) {String str = "hello";  // 局部变量str存储在栈中// ...}
}

2. 堆(Heap)

特点

  • 全局共享:所有线程共享同一个堆,用于存储对象实例和数组。
  • 动态分配:对象创建时在堆中分配内存,由垃圾回收器(GC)自动回收不再使用的对象。
  • 存储内容:
    • 对象实例:通过new创建的对象(如new Object())。
    • 数组:无论基本类型数组还是对象数组。
  • 内存管理:由 GC 负责回收垃圾对象,可能导致内存碎片和性能开销。
  • 异常:如果堆空间不足,会抛出OutOfMemoryError

示例

public class HeapExample {public static void main(String[] args) {// 以下对象实例存储在堆中Person person = new Person("Alice", 25);int[] array = new int[10];// person和array的引用变量存储在栈中,指向堆中的对象}
}class Person {private String name;private int age;public Person(String name, int age) {this.name = name;this.age = age;}
}

3. 核心区别

对比项栈(Stack)堆(Heap)
内存分配线程私有,空间连续全局共享,空间不连续
存储内容局部变量、方法调用信息对象实例、数组
生命周期随线程创建和销毁随应用启动和关闭
访问效率慢(需通过引用间接访问)
内存管理自动分配和回收(栈帧弹出)由 GC 动态回收
异常类型StackOverflowErrorOutOfMemoryError

4. 常见问题

  • 栈溢出(StackOverflowError):递归过深、方法调用链过长。

    public void recursiveMethod() {recursiveMethod(); // 无限递归导致栈溢出
    }
    
  • 堆溢出(OutOfMemoryError):创建过多对象,GC 无法及时回收。

    List<Object> list = new ArrayList<>();
    while (true) {list.add(new Object()); // 不断创建对象导致堆溢出
    }
    

5. 内存可视化示例

假设执行以下代码:

public class MemoryExample {public static void main(String[] args) {int x = 10;User user = new User("Bob");process(user);}public static void process(User u) {u.setName("Alice");}
}class User {private String name;public User(String name) { this.name = name; }public void setName(String name) { this.name = name; }
}

内存布局示意图:

栈内存(Stack)                      堆内存(Heap)
┌───────────────────┐               ┌───────────────────┐
│ main() 栈帧       │               │                   │
│  x: 10            │               │  User对象         │
│  user → heap@0x123│ ────────────→ │  ┌─────────────┐  │
├───────────────────┤               │  │ name: "Bob" │  │
│ process() 栈帧    │               │  └─────────────┘  │
│  u → heap@0x123   │               │                   │
└───────────────────┘               └───────────────────┘

总结

  • 负责方法执行的上下文管理,存储局部变量和调用信息。
  • 负责存储对象实例,是垃圾回收的主要区域。
  • 理解堆栈的区别有助于排查内存相关的错误(如 OOM、SOE)和优化程序性能。
http://www.xdnf.cn/news/5719.html

相关文章:

  • vue实现进度条带指针
  • Elasticsearch 字段映射与数据类型
  • 面试专栏-03-Git的常用命令
  • 异构计算时代:混合编程的崛起与未来
  • 大型视频学习平台项目问题解决笔记
  • Megatron系列——流水线并行
  • KUKA机器人安装包选项KUKA.PLC mxAutomation软件
  • 产品功能更新迭代后需要重做算法备案吗?
  • Linux系统管理与编程20:Apache
  • 关于mac配置hdc(鸿蒙)
  • Nginx部署前端项目深度解析
  • 使用 Syncthing 在两台电脑之间同步文件:简单教程
  • 用drawdb.app可视化创建mysql关系表
  • 开源 RPA 工具深度解析与官网指引
  • 学习黑客Windows 病毒与威胁防护
  • Clickhouse 迁移到 Doris 的最佳实践
  • PyTorch 中的 Autograd 实现细节解析和应用
  • TCPIP详解 卷1协议 九 广播和本地组播(IGMP 和 MLD)
  • 力扣算法ing(69 / 100)
  • MongoDB使用x.509证书认证
  • 单片机Day10
  • 【Mysql基础】二、函数和约束
  • 职坐标IT培训:互联网行业核心技能精讲
  • Model.eval() 与 torch.no_grad() PyTorch 中的区别与应用
  • Scala和Spark的介绍
  • window server 2012安装sql server2008 r2
  • 每日c/c++题 备战蓝桥杯(洛谷P1387 最大正方形)
  • 工业协议跨界实录:零基础玩转PROFINET转EtherCAT主站智能网关
  • 网张实验操作-防火墙+NAT
  • 软考教材重点内容 信息安全工程师 第24章 工控安全需求分析与安全保护工程