哈喽,我是子牙。十余年技术生涯,一路披荆斩棘从技术小白到技术总监到JVM专家到创业。技术栈如汇编、C语言、C++、Windows内核、Linux内核。特别喜欢研究虚拟机底层实现,对JVM有深入研究。分享的文章偏硬核,很硬的那种。
手撸过JVM、内存池、垃圾回收算法、synchronized、线程池、NIO…
最近正在写三色标记算法 _
这样的硬核男人,怎么才能认识他?关注:硬核子牙
聊点啥这篇文章想跟大家聊聊Hotspot源码的call_stub,如图
这啥?这篇文章目前还不适合你,默默关掉吧,我理解的!
为什么要聊这个?我又看不懂!(白眼)给我硬看!
这个问题是卷Hotspot的小伙伴问得比较多的,每次回答就像顺藤摸瓜一样,小伙伴们顺着我的回答抛出一堆问题,我怕了,写篇文章把讲透吧,后面谁来问,这篇文章丢过去。看不懂?多看几遍!
坦白讲,就这么一段代码,涉及到的知识点还真不少:
- 函数指针宏变量定义花招
铺垫知识
先说宏,比较简单,就两个知识点:
- 宏定义,通过#define定义宏展开,预处理阶段直接替换
打个比方
这是比较简单的,有的宏定义就像函数一样,还传参,把人搞疯了!万变不离其宗,无脑替换就可以了。
接下来谈谈函数指针,这个一两句话讲不清,我就举个例子了
总结一下:函数指针的强大就在于它可以用来定义函数,这个函数你给它什么地址,它就把那块内存当成函数执行
如果这样说你还是不懂,百度一下吧
好,最后一个铺垫知识:花样定义变量
OK,万事具备,开始卷。
顺便提一嘴,我在做手写JVM小班,就是以手写JVM为契机教大家底层如:汇编、C、C++、 *** 作系统…底层最重要的不是视频,而是老师本人在你遇到问题的时候能指点你。如果你想学习底层,想成为技术大牛,来找我。
开始卷点开call_stub,是一个函数,长这样,函数体是一个宏
找到宏定义
手动展开
继续展开
还有一个碍事的CallStub,继续展开
最终结果
_call_stub_entry是什么?是JVM调用Java函数的那座桥。指向一段内存,这段内存代码在这生成的
这个函数,还有一个:entry_point,是看懂Hotspot运行时的关键。然,这两座大山将99%的人拒之门外。
当然,不包括我,我用内联汇编模拟写了一遍
OK,就到这里,清晰明了。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)