Java基础学习之图解new代码在计算机中的内存结构

一、 栈和堆的特点

1、栈内存的特点
栈内存存储的都是局部变量,变量一旦出了自己的作用域,这样才会释放内存空间。

2、堆内存特点
堆内存存储的是对象数据(引用类型数据,除8种基本类型以外的),对象一旦被使用完,并不会马上从内存中消失,而是等待垃圾回收器不定时把垃圾对象回收,这时候该对象才会消失,释放内存。
注:① 对象如果没有变量引用了,那么该对象就是一个垃圾对象。
② 凡是以new关键字创建的对象,jvm都会在堆内存开辟新的空间用于创建新的对象。

二、 应用实例

1、int[] grade = new int[3];的内存结构解释
数组的内存结构1

2、int[] grade1 = new int[2]; int[] grade2 = new int[2];的内存结构解释
数组的内存结构2

3、int[] grade1 = new int[2]; int[] grade2 = grade1;的内存结构解释(同一个数组对象)
数组的内存结构3

4、int[] grade = new int[2]; grade = null ;的内存结构解释
数组的内存结构4

5、int[][] grade = new int[3][4];的内存结构解释
数组的内存结构5

6、int[] grade = new int[3]; grade = int[4];的内存结构解释
数组的内存结构7

7、Person p = new Person(); p.name = "张三"; p.age = 18的内存结构解释
类的内存结构1

8、Person p1 = new Person(); Person p2 = new Person(); p1.name = "张三"; p2.name = "李四"; p1 = p2;的内存结构解释
类的内存结构2

9、static String country = "中国";的内存解释
static的内存结构

10、静态函数的内存解释
静态函数的内存结构

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
数据结构计算机科学非常重要的概念之一,它用于组织和存储数据以便有效地操作和访问。Java语言提供了丰富的数据结构库,包括数组、链表、栈、队列、树、图等。我将为你图解一些常见的数据结构及其在Java的实现。 1. 数组(Array):数组是一种线性数据结构,它按照顺序存储相同类型的元素。在Java,数组的大小在创建时就确定,并且可以通过索引访问和修改其的元素。 2. 链表(Linked List):链表是一种动态数据结构,它由节点组成,每个节点包含数据和指向下一个节点的引用。在Java,有单向链表和双向链表两种常见的实现方式。 3. 栈(Stack):栈是一种后进先出(LIFO)的数据结构,类似于我们生活的一叠盘子。在Java,可以使用Stack类或者使用LinkedList类来实现栈。 4. 队列(Queue):队列是一种先进先出(FIFO)的数据结构,类似于我们日常生活排队等待的情况。在Java,可以使用Queue接口或者使用LinkedList类来实现队列。 5. 树(Tree):树是一种非线性的数据结构,它由节点和边组成,每个节点可以有多个子节点。在Java,常见的树结构包括二叉树、二叉搜索树(BST)、AVL树、红黑树等。 6. 图(Graph):图是一种由节点和边组成的数据结构,节点表示实体,边表示实体之间的关系。在Java,可以使用邻接矩阵或邻接表来表示图,并通过深度优先搜索(DFS)或广度优先搜索(BFS)等算法来遍历图。 这些只是数据结构的一部分,Java还提供了其他更复杂的数据结构和算法库,可以根据具体需求选择合适的数据结构。希望以上图解能够帮助你更好地理解数据结构Java的实现。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值