zoukankan      html  css  js  c++  java
  • 堆和栈

    栈(stack)是由编译器自动分配和释放的一块内存区域,主要用于存放一些基本类型(如int、float等)的变量、指令代码、常量及对象句柄(也就是对象的引用地址)。栈内存的操作方式类似于数据结构中的栈(仅在表尾进行插入或删除操作的线性表)。

          栈的优势在于,它的存取速度比较快,仅此于寄存器,栈中的数据还可以共享。

          其缺点表现在,存在栈中的数据大小与生存期必须是确定的,缺乏灵活性。

    堆(heap)是一个程序运行动态分配的内存区域,在Java中,构建对象时所需要的内存从堆中分配。这些对象通过new指令“显式”建立,这种分配方式类似于数据结构中的链表。堆内存在使用完毕后,是由垃圾回收(Garbage Collection,GC)器“隐式”回收的。

          堆的优势是在于动态地分配内存大小,可以“按需分配”,其生存期也不必事先告诉编译器,在使用完毕后,Java的垃圾收集器会自动收走这些不再使用的内存块。

          其缺点为,由于要在运动时才动态分配内存,相比于栈内存,它的存取速度较慢。

    栈(stack) 堆(heap)
    它的存取速度比较快                                                         由于要在运动时才动态分配内存,相比于栈内存,它的存取速度较慢。
    存在栈中的数据大小与生存期必须是确定的,缺乏灵活性。 动态地分配内存大小,可以“按需分配”,其生存期也不必事先告诉编译器

    原文:https://www.cnblogs.com/Hellorxh/p/10832256.html

  • 相关阅读:
    Redis简单梳理及集群配置
    PDF.js 详情解说
    基于SMS短信平台给手机发送短信
    linux装OpenOffice后传---中文乱码的解决
    NodeJs小试牛刀--聊天室搭建
    算法之路--最小代价生成树
    Linux系统上安装OpenOffice
    项目部署之工具使用心得
    H5 Handlebars的简单使用
    JavaWeb国际化
  • 原文地址:https://www.cnblogs.com/czh64/p/12012436.html
Copyright © 2011-2022 走看看