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”则作为字符串变量存在方法区中。

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

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


目录
相关文章
|
4天前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
16 2
|
8天前
|
Java 编译器
探索Java中的异常处理机制
【10月更文挑战第35天】在Java的世界中,异常是程序运行过程中不可避免的一部分。本文将通过通俗易懂的语言和生动的比喻,带你了解Java中的异常处理机制,包括异常的类型、如何捕获和处理异常,以及如何在代码中有效地利用异常处理来提升程序的健壮性。让我们一起走进Java的异常世界,学习如何优雅地面对和解决问题吧!
|
14天前
|
存储 Java 编译器
Java内存模型(JMM)深度解析####
本文深入探讨了Java内存模型(JMM)的工作原理,旨在帮助开发者理解多线程环境下并发编程的挑战与解决方案。通过剖析JVM如何管理线程间的数据可见性、原子性和有序性问题,本文将揭示synchronized关键字背后的机制,并介绍volatile关键字和final关键字在保证变量同步与不可变性方面的作用。同时,文章还将讨论现代Java并发工具类如java.util.concurrent包中的核心组件,以及它们如何简化高效并发程序的设计。无论你是初学者还是有经验的开发者,本文都将为你提供宝贵的见解,助你在Java并发编程领域更进一步。 ####
|
19天前
|
XML 安全 Java
Java反射机制:解锁代码的无限可能
Java 反射(Reflection)是Java 的特征之一,它允许程序在运行时动态地访问和操作类的信息,包括类的属性、方法和构造函数。 反射机制能够使程序具备更大的灵活性和扩展性
33 5
Java反射机制:解锁代码的无限可能
|
9天前
|
缓存 算法 Java
本文聚焦于Java内存管理与调优,介绍Java内存模型、内存泄漏检测与预防、高效字符串拼接、数据结构优化及垃圾回收机制
在现代软件开发中,性能优化至关重要。本文聚焦于Java内存管理与调优,介绍Java内存模型、内存泄漏检测与预防、高效字符串拼接、数据结构优化及垃圾回收机制。通过调整垃圾回收器参数、优化堆大小与布局、使用对象池和缓存技术,开发者可显著提升应用性能和稳定性。
30 6
|
7天前
|
Java 数据库连接 开发者
Java中的异常处理机制及其最佳实践####
在本文中,我们将探讨Java编程语言中的异常处理机制。通过深入分析try-catch语句、throws关键字以及自定义异常的创建与使用,我们旨在揭示如何有效地管理和响应程序运行中的错误和异常情况。此外,本文还将讨论一些最佳实践,以帮助开发者编写更加健壮和易于维护的代码。 ####
|
13天前
|
存储 缓存 安全
Java内存模型(JMM):深入理解并发编程的基石####
【10月更文挑战第29天】 本文作为一篇技术性文章,旨在深入探讨Java内存模型(JMM)的核心概念、工作原理及其在并发编程中的应用。我们将从JMM的基本定义出发,逐步剖析其如何通过happens-before原则、volatile关键字、synchronized关键字等机制,解决多线程环境下的数据可见性、原子性和有序性问题。不同于常规摘要的简述方式,本摘要将直接概述文章的核心内容,为读者提供一个清晰的学习路径。 ####
34 2
|
13天前
|
安全 IDE Java
Java反射Reflect机制详解
Java反射(Reflection)机制是Java语言的重要特性之一,允许程序在运行时动态地获取类的信息,并对类进行操作,如创建实例、调用方法、访问字段等。反射机制极大地提高了Java程序的灵活性和动态性,但也带来了性能和安全方面的挑战。本文将详细介绍Java反射机制的基本概念、常用操作、应用场景以及其优缺点。 ## 基本概念 ### 什么是反射 反射是一种在程序运行时动态获取类的信息,并对类进行操作的机制。通过反射,程序可以在运行时获得类的字段、方法、构造函数等信息,并可以动态调用方法、创建实例和访问字段。 ### 反射的核心类 Java反射机制主要由以下几个类和接口组成,这些类
31 2
|
14天前
|
存储 安全 Java
什么是 Java 的内存模型?
Java内存模型(Java Memory Model, JMM)是Java虚拟机(JVM)规范的一部分,它定义了一套规则,用于指导Java程序中变量的访问和内存交互方式。
36 1
|
18天前
|
存储 缓存 安全
🌟Java零基础:深入解析Java序列化机制
【10月更文挑战第20天】本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
22 3