源码全开放,没人看——一个框架作者的真实经历

源码全开放,没人看------一个框架作者的真实经历

先说结论

好奇心是天生的。你不能培养它,只能筛选它。

我知道这话不好听。但这是我花了十几年得出的结论。


被封锁的痛

2007年,我在一家公司做平台本地化。平台代码做了混淆,类名方法名全换成a、b、c,反编译出来像天书。我硬是debug + 反编译,跟了两周,画了十几张A4纸的映射图,把整个架构摸清了。

那个过程很苦。但我超级不服气------凭什么不让我看?你越封,我越要看。

这种不服气,不是培训出来的。


反过来,我全开放

后来我自己写了框架。从IOC容器到AOP到数据层到工作流,一行一行写出来的。

我的做法和那家公司完全相反:源码全开放。 所有用这套框架的公司,所有开发人员,都能看到完整的源文件。离职了?带走。想改?随便改。

我以为这会点燃什么东西。

没有。


讲了一场JVM,听后即完

有段时间我主动组织技术分享。讲JVM------不是那种PPT念一遍的讲法,是真刀真枪的内容:

  • ClassLoader------双亲委派机制,为什么你的类加载器和Bootstrap的不一样,自定义ClassLoader能干什么
  • 字节码加密解密------class文件在磁盘上是加密的,ClassLoader加载时解密,怎么实现
  • JVM结构------方法区、堆、栈各存什么,为什么字符串在堆里不在栈里
  • 初始化顺序------静态块、实例块、构造函数,父类子类,谁先谁后
  • 堆区结构------新生代老年代,Minor GC和Full GC的区别,为什么大对象直接进老年代
  • Java为什么不用寄存器------为了跨平台,JVM是一台虚拟的栈式机器,所有操作压栈弹栈,不依赖物理寄存器。这是Java"一次编译到处运行"的底层代价

讲的时候有人在听。讲完之后?没了。

没有人回去自己试。没有人第二天来问我"那个ClassLoader自定义的能不能给我演示一下"。没有人。

就像一场雨下在水泥地上,当时看着湿了,太阳一出来,干干净净。


慢慢就不讲了

不是生某人的气。是慢慢接受了一个事实:多数人不需要知道这些。

他们需要的是:这个接口怎么调,这个配置项填什么值,这个报错怎么解决。框架对他们来说是工具,不是研究对象。

这没有错。你用微波炉热饭,不需要知道磁控管的原理。

但这也意味着:你永远成不了造微波炉的人。


好奇心是筛选问题,不是培养问题

管理书上喜欢写"如何激发团队的好奇心"、"如何打造学习型组织"。

我的经验是:你激发不了。

好奇心就像色觉。有的人看世界是彩色的,有的人就是分不清红和绿。你没法教一个色盲看到红色,同样,你没法教一个不好奇的人追问"为什么"。

你能做的只有两件事:

1. 招人的时候筛选。

别问"你会不会Spring",问"你最近自己折腾了什么"。答不上来的,大概率不是你要找的人。

2. 给好奇的人留空间。

别把所有人的时间填满。好奇心需要空闲才能生长。天天加班赶需求的人,没有精力追问"为什么"。

至于其他人------他们踏踏实实完成工作,养家糊口,这本身很好。不是每个人都需要成为架构师。


最后

我反编译别人的混淆代码,是因为我受不了"不让我看"。我写框架开放源码,是因为我不想让别人受同样的苦。

但大多数人不觉得苦。他们觉得"能用就行"。

这不是他们的错。这只是说明:那个让我在凌晨三点还在debug的不服气,是我自己的东西,不是我能给别人的东西。


相关阅读:

  • 《debug驱动学习------三次debug改变我的技术认知》
  • 《造过轮子的人学框架有多快------我自己写完IOC和AOP,Spring就是换个API》
  • 《老木匠、临界质量与Log曲线------一个46岁架构师的AI生存哲学》
相关推荐
YGY顾n凡2 小时前
我开源了一个项目:一句话创造一个AI世界!
前端·后端·aigc
SamDeepThinking2 小时前
写了十几年代码,聊聊什么样的人能做好Java开发
java·后端·程序员
凛_Lin~~2 小时前
安卓实现textview跑马灯效果
android·java
我母鸡啊2 小时前
软考架构师故事系列-数据库系统
后端·架构
开源盛世!!2 小时前
4.20-4.22
java·服务器·开发语言
京师20万禁军教头2 小时前
28面向对象(中级)-封装
java
tERS ERTS2 小时前
头歌答案--爬虫实战
java·前端·爬虫
byterun2 小时前
LangChain4j 完整学习指南:从入门到企业级应用实战,看完这一篇你就是AI应用开发工程师
后端