`

Java中的堆和栈

    博客分类:
  • java
 
阅读更多

1 相同点:都是RAM中存放数据的地方 
2 不同点: 
  a.栈:存取速度快,但大小生命周期固定,主要应用于基本数据类型(byte,int,long,float,double,char,boolean) 
  b堆:存取速度慢,但能动态分配内存,主要应用于对象(new方式建立) 
3 示例: 
  int a=1; 
  int b=1; 
  那么在栈中只有一个1,a和b同时指向它,因此节省内存空间。 
 同理: 如果 
String x = "one"; 
  String y= "one"; 
  则 x == y 返回 true, 
如果 String x=new String("one"); 
String y= new String("one"); 
则 x==y 返回false,因为前一个存在栈里面,引用同一个“one”,而后者存放在堆里,分别建立对象。 
4 与C++比较,java自动垃圾回收机制,因此堆栈都由系统分配,而C++中堆有程序员分配,而栈由系统分配。

 

 

  首先,明确两个概念:数据结构与数据存储结构!

数据结构: 是指相互之间存在一种或多种特定关系的 数据元素 的 集合。听起来是不是很抽象,简单理解:数据结构就是描述对象间逻辑关系的学科。比如:队列就是一种先进先出的逻辑结构,栈是一种先进后出的逻辑结构,家谱 是一种树形的逻辑结构!(初学数据结构的时候很不理解为什么有“栈”这个东西;队列很容易理解---无论购物就餐都需要排队;栈可以认为就是个栈道--- 只允许一个人通过的小道,而且只能从一端进入,然后再从这端返回,比如你推了个箱子进去啦,第二个人也推个箱子进去,此时只能等后进来的这个人拉着箱子出 去后,你才能退出。)

数据存储结构: 它是计算机的一个概念,简单讲,就是描述数据在计算机中存储方式的学科;常用的数据存储方式就两种:顺序存储,非顺序存储!顺序存储就是把数据存储在一块连续的存储介质(比如硬盘或内存)上 ---- 举个例子:从内存中拿出第 100 个字节到 1000 个字节间的连续位置,存储数据;数组就是典型的顺序存储!非顺序存储就是各个数据不一定存在一个连续的位置上,只要每个数据知道它前面的数据和后面的数据,就能把所有数据连续起来啦;链表就是典型的非顺序存储啦!

    至此,基本就应该明白它们之间的区别了吧!

    队列、栈是线性数据结构的典型代表,而数组、链表是常用的两种数据存储结构;队列和栈均可以用数组或链表的存储方式实现它的功能!

//========================简单分析===============================

    数 组属于顺序存储中,由于每个元素的存储位置都可以通过简单计算得到,所以访问元素的时间都相同(直接访问数组下标);链表属于数据的链接存储,由于每个元 素的存储位置是保存在它的前驱或后继结点中的,所以只有当访问到其前驱结点或后继结点后才能够按指针访问到自己,访问任一元素的时间与该元素结点在链接存 储中的位置有关。

    链表和数组是常用的两种数据存储结构,都能用来保存特定类型的数据。两者存在着一些差异:

1. 占用的内存空间

    链表存放的内存空间可以是连续的,也可以是不连续的,数组则是连续的一段内存空间。一般情况下存放相同多的数据数组占用较小的内存,而链表还需要存放其前驱和后继的空间。

2. 长度的可变性

    链表的长度是按实际需要可以伸缩的,而数组的长度是在定义时要给定的,如果存放的数据个数超过了数组的初始大小,则会出现溢出现象。

3. 对数据的访问

    链表方便数据的移动而访问数据比较麻烦;数组访问数据很快捷而移动数据比较麻烦。

    链表和数组的差异决定了它们的不同使用场景,如果需要很多对数据的访问,则适合使用数组;如果需要对数据进行很多移位操作,则设和使用链表。

上面提到的都是栈,而不是堆栈,那堆栈是什么呢?

首先,堆栈是计算机语言中常用术语,堆栈是栈的俗称!

    比如在Java中我们常常说堆栈什么什么的,其实就是说栈内信息!此时有人就问:Java中明明有堆和栈两个概念呀?!不错,堆和栈的确是两种不同的内存操作单元,它们用途不同,但堆栈就是栈的俗称,你可以理解它其实就是栈!

堆和栈有什么区别:

1. 栈具有数据结构中栈的特点,后进先出,所有存放在它里面的数据都是生命周期很明确(当然要求它不能存放太久,占有的空间确定而且占用空间小),能够快速反应的!所有在Java中它存放的是8个基本数据类型和引用变量的,用完就马上销毁

2. 堆可以理解它就是个一个可大可小,任你分配的听话的内存操作单元;因此它的特点就是动态的分配内存,适合存放大的数据量!比如一个对象的所有信息,虽然它的引用指向栈中的某个引用变量;所有Java中堆是存放new出来的对象的。

    堆和栈因为不同的特性,所有在计算机中应用甚广

 

 

 

分享到:
评论
1 楼 ffyyhh995511 2014-07-11  
厉害厉害,受教了,写得很详细,大牛

相关推荐

    Java中堆和栈的区别

    ### Java中堆和栈的区别详解 #### 一、引言 在Java编程语言中,内存管理是一项非常重要的任务。为了确保程序的高效运行以及资源的有效利用,Java虚拟机(JVM)将内存划分为堆和栈两种类型。这两种内存区域各自承担着...

    java中堆和栈的区别.pdf

    Java中堆和栈的区别 Java是一种面向对象的编程语言,它的内存管理机制是自动化的,程序员不需要手动地分配和释放内存。Java中堆和栈是两个重要的概念,它们都是Java用于在RAM中存放数据的地方。 栈(Stack)是一块...

    Java中堆和栈的区别在哪?.pdf

    Java中堆和栈的区别在哪?.pdf

    JAVA中堆和栈的概念

    声明变量是在栈空间开辟了一个位置,实例化之后才会开辟一个堆空间 被赋予空值的话则是将栈空间地址指向一个新的堆空间位置

    详解java堆和栈

    ### 详解Java堆和栈 #### 一、引言 在Java编程中,理解堆(Heap)和栈(Stack)的概念及其区别对于程序员来说至关重要。本文将深入剖析这两个概念,并探讨它们之间的差异以及如何影响程序的运行。 #### 二、Java...

    JAVA中堆和栈的区别 - 路人浅笑 - 博客园.rar_java编程

    在Java编程中,堆和栈是两种非常重要的内存区域,它们各自承担着不同的职责,对于程序的运行效率和内存管理有着至关重要的作用。下面将详细阐述堆和栈的区别。 1. **栈(Stack)** - **定义**:栈是一种线性数据...

    java中的堆和栈

    ### Java中的堆和栈 #### 一、概述 在Java编程语言中,堆和栈是两种重要的内存区域,它们各自负责存储不同类型的数据。理解这两者之间的区别对于掌握Java内存管理和性能优化至关重要。本文将深入探讨Java中堆和栈...

    java里的堆和栈

    ### Java里的堆和栈 #### 一、概述 在Java编程中,“堆”与“栈”的概念至关重要。它们是程序运行时内存管理的核心部分。本文将深入探讨Java中堆和栈的区别及其工作原理。 #### 二、Java内存区域划分 在Java中,...

    Java 中的堆和栈

    Java编程语言中,内存管理是至关重要的概念,...总的来说,Java中的堆和栈内存是程序运行的基础,它们共同协作以提供高效、可靠的数据存储和管理。了解这两个内存区域的工作原理,有助于写出更高效、更稳定的Java代码。

    Java堆和栈的区别

    "Java 堆和栈的区别" Java 堆和栈是 Java 中的两种内存管理机制,它们都是 Java 用来在 RAM 中存放数据的地方。但是,它们有很多不同之处。 Java 堆是一个运行时数据区,类的对象从中分配空间。这些对象通过 new、...

    区别Java中的堆与栈

    描述:本文深入探讨了Java中堆和栈的基本概念、工作原理以及它们之间的显著差异,特别关注了它们在资源管理、性能表现和内存分配策略上的不同。 ### Java中的堆(Heap) Java的堆是运行时数据区域,主要用于存储...

    Java中堆内存与栈内存分配浅析

    程序运行时所使用的内存主要分为两类:堆内存(Heap Memory)和栈内存(Stack Memory)。理解这两种内存类型的工作原理及其区别对于优化程序性能、避免内存泄漏等问题至关重要。本文将深入探讨Java中堆内存与栈内存...

    Java中堆和栈的区别详解

    Java中的堆和栈是两种重要的内存区域,它们在程序执行时扮演着不同的角色。了解它们的区别对于优化程序性能和处理内存相关问题是至关重要的。 首先,栈(Stack)主要用于存储基本类型的变量(如int、float)和对象...

    java中堆和栈的区别分析

    在Java编程语言中,堆和栈是两种主要的内存区域,它们各自有不同的功能和特点。了解它们的区别对于优化程序性能和避免内存泄漏至关重要。 **堆(Heap)** 堆是Java运行时数据区的一部分,主要用于存储对象实例。当...

    区别Java中堆与栈区别Java中堆与栈

    Java 中的堆和栈是两个不同的内存区域,分别用于存放不同类型的数据。堆是一个运行时数据区,类的对象从中分配空间,通过new、newarray、anewarray 和 multianewarray 等指令建立,垃圾回收器会自动收走这些不再使用...

    Java 中的堆和栈.doc

    总的来说,理解Java中的堆和栈内存对于优化程序性能和避免内存问题至关重要。开发人员应合理利用栈的高效性和堆的灵活性,以及理解引用共享和对象创建的原理,以便编写出更高效、更健壮的Java代码。

    堆和栈详解

    堆和栈是计算机内存管理中的两个重要概念,它们在程序执行过程中起着至关重要的作用。在深入探讨这两个概念之前,我们需要明确一点:堆和栈在内存结构上有着本质的区别。 栈(Stack)是一种线性数据结构,其特点是...

    Java中堆内存和栈内存详解

    ### Java中堆内存和栈内存详解 #### 一、引言 在Java编程语言中,内存管理是一项核心技能。为了更好地理解和使用Java,必须清楚地了解堆内存与栈内存的区别及其工作原理。本文将深入探讨Java中堆内存与栈内存的概念...

Global site tag (gtag.js) - Google Analytics