前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >贡献一道超高套路JVM面试题(二)

贡献一道超高套路JVM面试题(二)

原创
作者头像
子牙老师
修改2022-05-06 16:13:14
2670
修改2022-05-06 16:13:14
举报
文章被收录于专栏:手写JVM专栏

哈喽,我是子牙。十余年技术生涯,一路披荆斩棘从技术小白到技术总监到JVM专家到创业。技术栈如汇编、C语言、C++、Windows内核、Linux内核。特别喜欢研究虚拟机底层实现,对JVM有深入研究。分享的文章偏硬核,很硬的那种。

手撸过JVM、内存池、垃圾回收算法、synchronized、线程池、NIO、三色标记算法…

本篇文章是接上篇文章【贡献一道超高套路JVM面试题】写的,如果你还没看过,墙裂都建议你看一下。

上篇文章我给出的结论是:下面这段创建对象的代码,在JVM中只会创建一个对象,并给出了强有力的证明。并且说到,父类的属性也是存储在子类对象中的,同样也给出了铁证。

但是今天在手撸JVM的过程中,我又陷入了深深的思考:父类中公共属性存储到子类对象上我能理解,父类中的私有属性为什么也要这么干呢?于是开启了一连串的风骚操作,最终找到了答案。为了方便大家拿去考核人才,我把它提炼成了又一道面试题:通过子类对象能访问父类对象的私有属性吗?如果不能,为什么要把父类的私有属性存储到子类对象上?

探索访问父类私有属性

直接访问的方式肯定是不行的,这个应该没争议吧!额,你有?建议把Java基础拿起来再看一遍。这时候我在想,如果Idea等开发工具如果不报错,会不会真的有小伙伴这样写,然后反手就run。哈,开玩笑的,最菜的肯定是我咯。

大家平时写代码的普遍做法都是定义get、set方法去访问私有属性,没毛病。

如果我问:通过反射能不能访问到?是不是有小伙伴陷入了思考:能?不能?么事,敲代码验证。

是访问不到的。方法getDeclaredField只能获取当前类的所有成员属性,不论是private、protect、public还是static的。

我发现

那为什么要这么做呢?说下我的两个理解。

1、如果不这样做,JVM OOP机制在实现的时候就需要创建父类对象,访问属性时就要加判断,如果是父类属性要沿着继承链往上找,如果继承链过长,就有性能问题了。如果继承链10层,就会多创建10个对象,找到属性极端要经过10次遍历。伪代码如下

2、如果不这样做,就不统一,程序就不好写了。就像你给前端写了个接口,比如要返回一个字段,你这边做了判断,如果为空就没有那个字段,这让前端就很奔溃了。一般前端取值都是默认有这个字段,她只判断是否为空。前端没脑子?前端妹子多呀!好看的妹子不带脑子怎么了?所以管理经验这东西,也不是看书就能学会的,也不是每个团队遵循的规范都得是一样的,得先了解这个团队,了解那几个常犯错的人的犯错习惯,制定特殊照顾规则。

有些东西,你只有从设计者的角度去思考,才能真正理解设计者。这也就是代码那么难懂的原因,因为你很难把自己真正摆在一个设计者的角度去思考问题,大多时候,你是阅读者。

对于底层,我的经验是:一个大的项目都是由无数小知识点组成的,那些个你很生疏的知识点,你自己试着去写一写,会有意想不到的收获。当你写得多了,你会发现,你学任何东西都比别人快,比别人理解得深。因为你能够触类旁通。

再给大家补个知识点点吧。大家用Idea、HSDB查看会发现,属性的位置是不一样的。其实正确的是HSDB,言外之意:在内存中,父类的属性是在子类属性前面的,因为是先调用父类的构造方法的属性赋值,再执行本类的构造方法完成本类中属性的赋值。

题外话

子牙手写JVM小班四期正在招生。四期新增了字节码增强+Agent,学完你就可以做JVM相关的工作,如二开arthas,自研类hsdb调试器、自研实现热更新热部署零侵入日志等黑科技…

四期完整课程包含七大专题+一个增值专题,约50多个课时。完整学完你就可以:1、用Java写一个Java虚拟机,从而深入理解运行系统的底层细节;2、有能力自行研究Hotspot源码及其他用C语言、C++写的中间件源码;3、能够用C语言、C++写任何你感兴趣的基础算法如:内存池、垃圾回收算法、主从同步算法、执行引擎、存储引擎;4、就有底子跟着我学习下半年准备开的操作系统内核班……

这套课程,横跨多个计算机学科,但只是一个学科的价格。这套课程,JVM专家、功力深厚、经验丰富的子牙老师亲授,跟我学习不踩坑,全网唯一教授虚拟机的课程…

感兴趣小伙伴可以加班班微信咨询(jvm-anan),真诚招生,无任何套路。课程试看,问题真诚解答,全部了解清楚再上车。一二三期共500多VIP加入,无一人退费,好评不断

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 探索访问父类私有属性
  • 我发现
  • 题外话
相关产品与服务
消息队列 TDMQ
消息队列 TDMQ (Tencent Distributed Message Queue)是腾讯基于 Apache Pulsar 自研的一个云原生消息中间件系列,其中包含兼容Pulsar、RabbitMQ、RocketMQ 等协议的消息队列子产品,得益于其底层计算与存储分离的架构,TDMQ 具备良好的弹性伸缩以及故障恢复能力。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档