java内存机制详解,老年人也看得懂

简介: java内存机制详解,老年人也看得懂

您的一个赞或者是评论区的一句话都将是对我最大的激励。


刚学编程的时候,被什么引用变量,静态变量,对象搞得混淆不清,给自己学习编程增加了很大的难度,希望通过本篇文章,能对大家有所帮助。

先来介绍一个简单的概念:

Case cc =new Case();    //这是我们很熟悉的语句,这条语句可以分解为
Case cc;   //其中cc叫做引用变量,在栈内存里面开辟,此时cc=null
cc=new Case();  // new  Case()是在堆内存里面开辟了空间给Case类的对象,这个对象没有名字,
//Case()随即调用了Case类的构造函数,把对象的地址在堆内存的地址给引用变量cc

我们不要把事情想的太复杂了,简单明了的说 Java虚拟机的内存可以分为三个区域:栈stack、堆heap、方法区method area

这3个区各有各的特点,我简单整理罗列了一下方便各位理解:

栈的特点如下:

1. 栈描述的是方法执行的内存模型。每个方法被调用都会创建一个栈帧(存储局部变量、操作数、方法出口等)


2. JVM为每个线程创建一个栈,用于存放该线程执行方法的信息(实际参数、局部变量等)


3. 栈属于线程私有,不能实现线程间的共享!


4. 栈的存储特性是“先进后出,后进先出”

5. 栈是由系统自动分配,速度快!栈是一个连续的内存空间!

堆的特点如下:

1. 堆用于存储创建好的对象和数组(数组也是对象)

2. JVM只有一个堆,被所有线程共享

3. 堆是一个不连续的内存空间,分配灵活,速度慢!

方法区(又叫静态区)特点如下:

1. JVM只有一个方法区,被所有线程共享!

2. 方法区实际也是堆,只是用于存储类、常量相关的信息!

3. 用来存放程序中永远是不变或唯一的内容。(类信息Class对象、静态变量、字符串常量等)

方法区也是位于堆中的,只不过作用较为特殊,我们单独提取出来。所以java虚拟机内存其实就只有栈 和 堆 ,下面我放一张图让大家进一步理解2这的区别。

为了让老年人也看得懂,我再放一张图,简单描述三者在内存中的关系

结合我最先前说的Case cc =new Case()的概念,这样我们就明确了
这里的“=”并不是赋值的意思,而是把对象的地址传递给变量,有点类似指针。

1.图中的15db9742和15db9753这个数字是我自己编的,代表对象在堆中的地址,但是这个地址是会变化的,这个要特别注意!

2.字符串常量一般也都是存储在方法区中

懂了之后我们来看三个问题
题1:
int a = 1 ,a和1分别存在于哪里?

答:

1. a作为类的成员变量,存放于方法区中;1保存在堆(Heap)的实例中

2. a作为方法局部变量,存放于Java虚拟机栈(JVM Stacks)的局部变量表中;1保存在栈内存中。

题2:
String str=new String(“abc”) 创建了几个对象

答:

一个或者2个, 我们可以把上面这行代码分成 String str 、= 、 “abc” 和 new String() 四部分来看待。 String str只是定义了一个名 为str的String类型的变量,因此它并没有创建对象;

= 号是对变量str进行初始化,将某个对象的引用赋值给它,也没有创建对象;

所以说如果字符串常量池里有"abc",我们就只创建了 new String一个对象;

如果没有"abc" ,我们就创建了 new String和 "abc"2个对象。

题3:

String a=“123” a在哪里?“123”又存储在哪里

答:

通过题1,我们已经有经验了,如果说a是成员变量,则a存在方法区中,如果说a是局部变量,则a存在栈中,“123”则作为字符串变量存在方法区中。

本篇文章我还是介绍的比较详细的,相信大家都有所收获。

白嫖不好,创作不易。各位的点赞就是我创作的最大动力,如果我有哪里写的不对,欢迎评论区留言进行指正,我们下篇文章见!


目录
相关文章
|
7天前
|
Java 程序员 Windows
【Java知识点详解 10】为何要配置环境变量,35岁老年程序员的绝地翻身之路
【Java知识点详解 10】为何要配置环境变量,35岁老年程序员的绝地翻身之路
|
7天前
|
缓存 安全 Java
7张图带你轻松理解Java 线程安全,java缓存机制面试
7张图带你轻松理解Java 线程安全,java缓存机制面试
|
8天前
|
算法 程序员 调度
深入理解操作系统的内存管理机制
【5月更文挑战第9天】 在现代计算机系统中,操作系统的内存管理是一个至关重要的部分,它直接影响到系统的性能和稳定性。本文将深入探讨操作系统的内存管理机制,包括物理内存的管理、虚拟内存的概念和应用,以及内存分配和回收的策略。通过对这些内容的深入理解,我们可以更好地理解操作系统的工作原理,提高我们的编程效率和质量。
|
1天前
|
存储 Java
【JAVA学习之路 | 进阶篇】ArrayList,Vector,LinkedList内存解析
【JAVA学习之路 | 进阶篇】ArrayList,Vector,LinkedList内存解析
|
2天前
|
存储 缓存 算法
深入理解操作系统的内存管理机制
【5月更文挑战第21天】 在现代计算机系统中,操作系统扮演着至关重要的角色,它负责协调和管理硬件资源,确保系统高效稳定地运行。其中,内存管理是操作系统核心功能之一,直接关系到整个系统的性能和稳定性。本文将深入探讨操作系统中的内存管理机制,包括物理内存与虚拟内存的映射、分页系统的工作原理及其优化方法。通过对这些概念和技术的剖析,我们可以更好地理解操作系统如何有效地利用有限的内存资源,满足多任务并发执行的需求。
|
2天前
|
存储 缓存 监控
Java一分钟之-Apache Ignite:分布式内存计算平台
【5月更文挑战第21天】Apache Ignite是一款开源的分布式内存计算平台,涉及内存数据网格、流处理和计算服务。本文关注其常见问题,如数据丢失、分区不均、内存管理和网络延迟。为保证数据一致性,建议使用适当的數據模式和备份策略,实现数据持久化。优化内存配置和监控网络可提升性能与稳定性。提供的Java代码示例展示了如何创建分区缓存并设置备份。正确配置和管理Ignite是构建高可用、高性能应用的关键,持续监控集群状态至关重要。
16 0
|
2天前
|
缓存 监控 Java
Java一分钟之-Apache Geode:分布式内存数据平台
【5月更文挑战第21天】Apache Geode是低延迟的分布式内存数据平台,用于构建实时应用,提供缓存、数据库和消息传递功能。本文聚焦于Geode的常见问题,如数据一致性(数据同步延迟和分区冲突)和性能瓶颈(网络延迟和资源管理不当),并提出解决方案。确保数据一致性可通过选择合适的数据策略和利用`InterestPolicy`、`CacheListener`;提升性能则需优化网络和合理配置资源。通过示例代码展示了如何创建和操作Geode的Region。正确配置和调优Geode对于实现高可用、高性能应用至关重要。
18 1
|
3天前
|
存储 缓存 开发者
深入理解操作系统的内存管理机制
【5月更文挑战第20天】 在现代计算机系统中,操作系统扮演着至关重要的角色,它负责协调和管理硬件资源。内存管理是操作系统的核心职能之一,关系到系统性能和稳定性。本文将深入剖析操作系统内存管理的关键技术,包括虚拟内存、分页机制、内存分配策略等,旨在为读者提供一个清晰的理解框架。通过对这些技术的探讨,我们能够更好地认识到操作系统如何高效地利用有限的物理内存,满足多任务并行处理的需求。
|
5天前
|
算法 Java Python
【Python 的内存管理机制专栏】Python 内存管理实战:性能优化与内存泄漏检测
【5月更文挑战第18天】Python内存管理关乎程序性能与稳定性。优化包括避免过多临时对象,如优化列表推导式减少对象创建。警惕循环引用造成的内存泄漏,如示例中的Node类。使用`gc`模块检测泄漏,通过`gc.set_debug(gc.DEBUG_LEAK)`和`gc.collect()`获取信息。实践中需持续分析内存使用,优化算法、数据结构和资源释放,以提升程序质量与效率。
【Python 的内存管理机制专栏】Python 内存管理实战:性能优化与内存泄漏检测
|
5天前
|
存储 Java 程序员
【Python 的内存管理机制专栏】深入解析 Python 的内存管理机制:从变量到垃圾回收
【5月更文挑战第18天】Python内存管理关乎程序性能与稳定性,包括变量存储和垃圾回收。变量存储时,如`x = 10`,`x`指向内存中值的引用。垃圾回收通过引用计数自动回收无引用对象,防止内存泄漏。了解此机制可优化内存使用,避免循环引用等问题,提升程序效率和稳定性。深入学习内存管理对成为优秀Python程序员至关重要。
【Python 的内存管理机制专栏】深入解析 Python 的内存管理机制:从变量到垃圾回收