`
van_dx
  • 浏览: 17831 次
  • 性别: Icon_minigender_1
  • 来自: 南京
最近访客 更多访客>>
社区版块
存档分类
最新评论

[Java]Heap与stack

 
阅读更多

1) Heap(堆)是 Stack(栈)的一个子集。

 

2) Stack存取速度仅次于寄存器,Stack里面的数据可共享,但是其中数据的大小和生存期必须在运行前确定。

 

3) Heap是运行时可动态分配的数据区,从速度看比Stack慢,Heap里面的数据不共享,大小和生存期都可以在运行时再确定。

 

4) new关键字 是运行时在Heap里面创建对象。每new一次都一定会创建新对象,因为堆数据不共享。

Eg: String str1= new String("abc");   (1)

         String str2= "abc";               (2)

 str1是在Heap里面创建的对象。

 str2是指向Stack里面值为“abc”的引用变量,语句(2)的执行,首先会创建引用变量str2, 再查找Stack里面有没有“abc”,有则将 str2指向 “abc”,没有则在Stack里面创建一个“abc”,再将str2指向“abc”。

 

 

 

 

分享到:
评论

相关推荐

    java中堆(heap)和堆栈(stack)有什么区别

    "Java 中堆(heap)和堆栈(stack)的区别" Java 中堆(heap)和堆栈(stack)是两个不同的内存区域,分别用于存储不同的数据类型和对象。堆栈(stack)是 Java 中的一种内存区域,用于存储基本类型的变量和对象的...

    java解决nested exception is java.lang.OutOfMemoryError Java heap space

    Java内存主要分为三个区域:堆(Heap)、栈(Stack)和方法区(Method Area),其中堆是用于存储对象实例的主要区域,当堆空间不足时,就会抛出`OutOfMemoryError: Java heap space`。 1. **调整JVM堆大小**:可以...

    The Run-time Heap and Stack

    在IT领域,尤其是在操作系统与编程语言的运行时环境中,“运行时堆和栈”(The Run-time Heap and Stack)是理解程序内存管理的核心概念。本文旨在深入解析这一主题,结合提供的部分文档内容,详细阐述堆和栈的区别...

    记录java.lang.OutOfMemoryErrorJava heap space的情况.docx

    在Java程序中,`java.lang.OutOfMemoryError: Java heap space` 是一个常见的错误,意味着程序在运行过程中耗尽了JVM分配的堆内存。这个错误通常发生在创建大量对象或者单个对象占用过多内存时。 一、问题描述与...

    堆(heap)与栈(stack)的区别

    堆(heap)与栈(stack)是计算机内存管理中的两种基本数据结构,用于存储程序运行时产生的临时变量。在C语言中,这两种内存区域有非常明确的区分,对于理解程序的内存分配和回收具有重要意义。 首先,栈是一种特殊...

    java heap s

    Java堆空间(Heap Space)是Java虚拟机(JVM)管理的主要内存区域之一,用于存储对象实例和数组。当程序运行过程中,如果堆空间不足,Java应用程序可能会抛出`java.lang.OutOfMemoryError: Java heap space`异常。这...

    ibm HeapAnalyzer java内存分析工具 ha457.jar

    Java内存分为堆(Heap)、方法区(Method Area)、栈(Stack)、本地方法栈(Native Method Stack)和程序计数器(PC Register)五大部分。HeapAnalyzer主要关注的是堆内存,特别是新生代(Young Generation)、老...

    java 虚拟机 内存和栈 分析工具 ha456.rar

    Java内存主要分为堆(Heap)、栈(Stack)、方法区(Method Area)、程序计数器(PC Register)和本地方法栈(Native Method Stack)五大部分: 1. **堆**:Java对象主要存储在堆中,它是所有线程共享的一块区域。...

    深入Java虚拟机中的Stack和Heap

    "深入Java虚拟机中的Stack和Heap" 在Java虚拟机(JVM)中,内存分为两个部分:Stack(栈)和Heap(堆)。Stack是JVM的内存指令区,管理很简单,push一定长度字节的数据或者指令,Stack指针压栈相应的字节位移;pop...

    could not reserve enough space for object heap

    Java程序运行在JVM上,JVM将内存划分为几个区域,包括堆内存(Heap)、栈内存(Stack)、方法区(Method Area)、程序计数器(PC Register)和本地方法栈(Native Method Stack)。其中,堆内存是所有线程共享的一块...

    基于java中stack与heap的区别,java中的垃圾回收机制的相关介绍

    在Java中,内存主要分为两个区域:栈(Stack)和堆(Heap),以及垃圾回收机制(Garbage Collection)。 栈是程序执行过程中的临时数据存储区域,主要用于存储基本类型(如int、char)和对象的引用。每当一个方法被...

    IBM heapdump analyzer

    在一些平台上,在有些情况下,javacore也被称为javadump,它包含jvm和应用程序相关的在特定时刻的一些诊断信息,如操作系统,应用程序环境,线程,native stack本地堆,锁,和内存的信息。在生成heapdump文件的时候...

    深入Java虚拟机:JVM中的Stack和Heap

    "深入Java虚拟机:JVM中的Stack和Heap" Java虚拟机(JVM)是一种运行Java字节码的虚拟机环境,它具有自己的内存管理机制。JVM的内存分为两个部分:Stack(栈)和Heap(堆)。 Stack(栈)是JVM的内存指令区,管理...

    Java GC与性能调优

    * Runtime data area 组件:包括 Heap、Method Area、Java Stack、Program Counter 和 Native method stack 五个部分。 * Native interface 组件:与 native libraries 交互,是其它编程语言交互的接口。 二、 JVM ...

    java内存机制及异常处理

    5. **Native Method Stack(本地方法栈)**:与Java栈类似,但用于支持Java的本地接口(JNI)调用,即C/C++等本地方法的调用。 Java的垃圾回收机制采用分代收集算法,将堆分为年轻代(包括Eden和两个Survivor区)和...

    JStack和Java Thread Dumps分析

    在Java应用程序开发与维护过程中,时常会遇到性能瓶颈或死锁等问题。这些问题往往难以定位,尤其当系统处于高负载下时,更是如此。此时,`JStack`工具便显得尤为重要。它能够帮助我们收集并分析线程堆栈信息,进而...

    JAVA-OPTS参数设置.docx

    3. -Xmx:Java heap 最大值,使用的最大内存。这个值和 -Xms 的值同步设置,建议均设为物理内存的一半。 4. -XX:PermSize:设定内存的永久保存区域大小。 5. -XX:MaxPermSize:设定最大内存的永久保存区域大小。 ...

    北大青鸟JAVA面试题

    堆(Heap)和栈(Stack)是JAVA中两种重要的内存区域。堆是用于存储所有JAVA对象和数组的空间,其大小动态调整,由垃圾回收器管理。栈则是用于存储局部变量和方法调用的信息,每个线程都有自己的私有栈空间。 ### 8...

    java机制介绍

    - 栈内存(Stack)与堆内存(Heap):Java将内存分为栈内存和堆内存。栈内存用于存放基本类型变量和对象的引用变量,堆内存用于存放通过new创建的对象和数组以及对象的实例变量。 - 堆的优势:动态分配内存大小,...

    JMM-Heap-Stack:Eclipse 内存分析器、JProfiler、jconsole、jmc、jvisualvm、内存转储

    3. **栈内存(Stack)**: - 每个线程都有自己的程序计数器、虚拟机栈和本地方法栈。 - 栈内存主要用于存储基本类型变量、对象引用和方法调用过程中的局部变量。 4. **Eclipse内存分析器**: - Eclipse提供了...

Global site tag (gtag.js) - Google Analytics