`
klcwt
  • 浏览: 194590 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

再看heap 和stack,还有多了解内存

    博客分类:
  • java
阅读更多

heap

1.堆石一个“运行时”数据区,类实例化的对象就是从堆上分配的空间。

2.在堆上分配的空间一般通过new 等 等指令来创建

3.Java针对指针操作和C++的区别就是,java不需要在空间不用的时候显示释放。

4.JAVA的堆是由垃圾回收机制来负责处理的 ,堆是动态分配内存大小的,GC可以自动回收不在使用的内存空间

5.因为是动态内存所以 存取速度慢。

 

stack

1.存放基础数据类型和对象句柄

2.存取速度比堆快

3.stack的数据可以共享 (Int a=5 int b=5 两个变量都是用在stack的值)

4.stack的数据必须是大小和生命周期确定,缺乏灵活性。

 

可以看看你有多少内存

最大内存

System.out.print("maxMemory:");
System.out.println(Runtime.getRuntime().maxMemory()/1024/1024+"M");

已使用内存

System.out.println(Runtime.getRuntime().totalMemory()/1024/1024+"M");

 

设置java启动内存大小

-Xms256m -Xmx512m

-Xms<size> set initial Java heap size
-Xmx<size> set maximum Java heap size

 

二维数组比一维数组占用更多内存空间

 

用 "arrayCopy()" 提高数组截取速度


即使程序员可以做的只有调用 "System.gc()" 来 " 建议 " 执行垃圾收集器程序,但也不能保证gc执行

 

" 新生代 " 区域设置参数是 "-Xmn" ,用这个参数可以制定 " 新生代 " 区域的大小。

分享到:
评论

相关推荐

    stack&heap

    【堆和栈】是计算机内存...了解堆和栈的特性可以帮助程序员有效地管理内存,避免栈溢出和内存泄漏等问题,提高程序的稳定性和效率。在编写涉及大量内存分配和释放的程序时,特别需要注意内存管理,以确保程序的健壮性。

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

    "Java 中堆(heap)和堆栈(stack)的区别" Java 中堆(heap)和堆栈(stack)是两个不同的内存区域,...了解堆栈(stack)和堆(heap)的区别对于 Java 编程非常重要,可以帮助我们更好地理解 Java 的内存管理机制。

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

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

    The Run-time Heap and Stack

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

    C语言stack和heap

    在C/C++编程中,内存管理是至关重要的一个部分,主要分为栈(stack)和堆(heap)两个区域。理解这两个概念以及它们的区别对于优化程序性能、避免内存泄漏至关重要。 栈是程序运行时系统自动分配的一块内存区域,...

    heap and stack

    这个解释虽然简单,但具体取决于变量的数据类型,内存的分配方式也会有所不同,主要分为栈内存(Stack Memory)与堆内存(Heap Memory)。接下来,我们将详细解析这两种类型的内存。 ### 二、堆与栈:内存管理的...

    Z-stack OSAL堆内存管理

    Z-Stack的堆内存管理实现了一个简单的内存池,其中osalMemHdr_t类型的theHeap数组存储了所有内存块的控制头。内存池的大小由MAXMEMHEAP定义,控制头的大小由OSALMEM_HDRSZ定义,而osal_mem_init函数负责初始化整个...

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

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

    c语言stack(栈)和heap(堆)的使用详解

    3、全局区(静态区)(static)—全局变量和静态变量的存储是放在一块的,初始化的全局变量和静态变量在一块区域,未初始化的全局变量和未初始化的静态变量在相邻的另一块区域。程序结束后由系统释放。4、文字常量区...

    could not reserve enough space for object heap

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

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

    堆(heap)和栈(stack)是计算机科学中两个基本的内存分配概念,它们之间的区别是非常重要的。本文将详细介绍堆和栈的概念、差异、特点和应用场景。 一、预备知识—程序的内存分配 一个由 C/C++ 编译的程序占用的内存...

    IBM heapdump analyzer

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

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

    了解和熟练使用这些工具,结合JMM的知识,能够有效地排查和解决Java应用中的内存问题,提升程序的稳定性和性能。在实际开发中,应定期检查内存使用情况,及时发现并处理潜在的内存泄漏,保证程序的高效运行。

    heap exploit.pdf

    为了利用堆溢出,攻击者需要精确控制溢出数据,以及对堆内存管理和分配策略有深入了解。 堆利用技术包括但不限于以下几种: 1. 堆溢出(Heap Overflows):通过向程序的堆内存中写入超过分配大小的数据,攻击者...

    HeapAnalyzer

    Java内存主要分为堆内存(Heap)、方法区(Method Area)、栈内存(Stack)、程序计数器(PC Register)和本地方法栈(Native Method Stack)。其中,堆内存是Java对象的主要存储区域,也是HeapAnalyzer分析的重点。...

    深入Java虚拟机中的Stack和Heap

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

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

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

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

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

    heapAnalyzer

    Java内存主要分为堆(Heap)、栈(Stack)、方法区(Method Area)、程序计数器(PC Register)和本地方法栈(Native Method Stack)。heapAnalyzer主要关注的是堆内存,它是Java对象的主要存储区域,也是垃圾收集...

Global site tag (gtag.js) - Google Analytics