Java堆栈

转载自https://baijiahao.baidu.com/s?id=1631954351623041461&wfr=spider&for=pc

先用一张图展示一下Java堆栈的概况

方法区:class文件信息,运行时常量池,以及编译器编译后的代码堆:存储对象,对象包含类的信息,指向方法区

  • 虚拟机栈:表示Java方法执行的内存模型,每调用一个方法就会为每个方法生成一个栈帧(Stack Frame),用来存储局部变量表、操作数栈、动态链接、方法出口等信息。每个方法被调用和完成的过程,都对应一个栈帧从虚拟机栈上入栈和出栈的过程。虚拟机栈的生命周期和线程是相同的
  • 本地方法栈:一个支持native方法调用的JVM实现
  • 程序计数器:程序计数器用来记录当前正在执行的指令

用一个十分简单的代码段模拟一下Java堆栈的运行过程:

publicclassAppTest { publicstaticvoidmain(String[] args) { Person person = new Person("张三"); person.sayHello(); }}classPerson { String name; publicPerson(String name) { this.name = name; } publicvoidsayHello() { System.out.println("hello " + name); }}

新建一个main线程的一个栈jvm在方法区寻找是否存在Person类的信息如果没找到类加载器加载Person类信息到方法区,然后在堆中创建Person对象,并持有方法区的引用把person添加到main主线程栈中,并指向堆上的Person实例。执行person的sayhello方法,找到堆上的Person实例。根据堆上Person的方法区引用,找到方法区上sayhello的字节码,然后执行完成。

下面用一段十分简单的代码段描述一下栈的运行过程。

publicclassAppTest { publicstaticvoidmain(String[] args) { int a = 1; int b = 2; int c = add(a , b); } privatestaticintadd(int a, int b) { return a + b; }}

Python网络爬虫与推荐算法新闻推荐平台:网络爬虫:通过Python实现新浪新闻的爬取,可爬取新闻页面上的标题、文本、图片、视频链接(保留排版) 推荐算法:权重衰减+标签推荐+区域推荐+热点推荐.zip项目工程资源经过严格测试可直接运行成功且功能正常的情况才上传,可轻松复刻,拿到资料包后可轻松复现出一样的项目,本人系统开发经验充足(全领域),有任何使用问题欢迎随时与我联系,我会及时为您解惑,提供帮助。 【资源内容】:包含完整源码+工程文件+说明(如有)等。答辩评审平均分达到96分,放心下载使用!可轻松复现,设计报告也可借鉴此项目,该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的。 【提供帮助】:有任何使用问题欢迎随时与我联系,我会及时解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 下载后请首先打开README文件(如有),项目工程可直接复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值