Java进阶(一)Java内存解析

    栈、堆、常量池等虽同属Java内存分配时操作的区域,但其适用范围和功用却大不相同。本文将深入Java核心,简单讲解Java内存分配方面的知识。

    首先我们先来讲解一下内存中的各个区域。

stack(栈)

    存放基本类型的数据和对象的引用,即存放变量。

    如果存放的是基本类型数据(非静态变量),则直接将变量名和值存入stack中的内存中;

    如果是引用类型,则将变量名存入栈,然后指向它new出的对象(存放在堆中)。

heap(堆)

   存放new产生的数据。

data segment

   分为静态域和常量域。

静态域

   存放在对象中用static定义的静态成员(即静态变量,同理,如果该静态变量是基本类型则将变量名和值存入静态域,如果是引用类型则指向new出的对象)。

常量池

   常量池指的是在编译期被确定,并被保存在已编译的.class文件中的一些数据。除了包含代码中所定义的各种基本类型(如int、long等)和对象型(如String及数组)的常量值(final)还包含一些以文本形式出现的符号引用,比如:类和接口的全限定名;字段的名称和描述符;方法和名称和描述符。

   code segment:存放代码。

   下面我来举几个简单的小例子来让大家认识一下这几个区域具体存放的内容:

   注:例1和例2中大家要注意String类型不是基本数据类型,所以它可以创建对象,并且它的值是放在常量池中的。

例1. 非静态和静态变量的创建

   String str = "abc";  static Int a = 10;  //创建String类型的变量str;创建Int类型变量a

   内存解析:

   这里的str是非静态变量所以将其放入到栈中,而静态变量a则需要放入静态域中,对于变量值"abc"和10则都应该放入到常量池当中

例2. 对象的创建

   String str=new String("abc");  //创建String类型的对象str

   内存解析:

   这里的str是String类型的对象,所以放入栈中,而new出来的东西则放入到堆中,对于初始值"abc"则放入到常量池中即可。

 

例3. 数组的创建

   Int s[] = new Int[3];s[0]=3;s[1]=2;s[2]=3;

   内存解析:

   这里的s[]是一个数组变量,所以放入到栈中,new出来的东西还是放入到堆中,最后的每个元素的值则放入到常量池当中。

 

  • 41
    点赞
  • 59
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 9
    评论
如果你想在Java后端开发中进阶学习,以下是一些建议可以考虑: 1. 深入学习Java高级特性:掌握Java的高级特性,如多线程编程、并发编程、Lambda表达式、函数式编程等,可以提升你的编程能力和代码质量。 2. 学习Linux基础知识:Linux是大数据开发中常用的操作系统,了解Linux的基本命令和操作可以帮助你更好地进行开发和调试。 3. 掌握大数据技术:大数据开发需要掌握一系列的技术和工具,包括Hadoop、HBase、Hive、Kafka、Storm、Scala、Python、Spark等。逐步学习和实践这些技术,可以帮助你构建大数据应用和进行数据分析。 4. 学习机器学习算法:了解常用的机器学习算法,如分类、回归等,可以帮助你在大数据开发中进行数据挖掘和分析。 5. 实践项目经验:通过参与实际的项目开发,可以锻炼你的技术能力和解决问题的能力。可以尝试在实际项目中应用所学的技术和工具,积累项目经验。 总之,要进阶学习Java后端开发中的大数据方向,需要系统地学习和实践相关的技术和工具。不断提升自己的技术能力和项目经验,可以帮助你在大数据领域取得更好的发展。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* [Java面试题目,外包Java后端开发三年,算法太TM重要了](https://blog.csdn.net/m0_56662547/article/details/116647529)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [从 Java 后端开发,如何转到大数据开发(Hadoop/Kafka/Spark)?](https://blog.csdn.net/github_38592071/article/details/103826043)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

No Silver Bullet

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值