架构师动手写了一个 helloworld!
架构师不造工具,今天造了一个 helloworld!
今天我们不聊技术,聊一聊过渡设计。
我们以 helloworld 为例!普通程序员写了一个 Java 输出 hello world 程序!架构师一看,满脸不屑。到处找钉子,你的程序太 low 了,不支持多语言,不支持友好扩展!
然后架构师动手写了一个 hello world!
架构师的思路如下:
main 函数里 print 一下?
太面向过程,太 low 了。得封装一个类。叫 Printer,Printer 有个成员方法,叫 print。
但是!光一个类太 low 了,以后要是有不同的实现怎么办?所以得加一个接口。PrinterInterface。
但是!interface 是没有实现的,还是要有默认实现才行。所以得加个抽象类,AbstractPrinter 实现 PrinterInterface,然后 Printer 继承 AbstractPrinter。
但是!你有了那么一套,该怎么创建实例呢?直接 new Printer()?太 low 了,那叫实现依赖。肯定不行的,所以要搞一个工厂类,PrinterFactory,PrinterFactory 用 PrinterInterface 返回实例,这样就隐藏了实现细节了。
但是!PrinterFactory 本身也是实现类啊,太 low 了,所以得有 PrinterFactoryInterface,AbstractPrinterFactory。
而且在 PrinterFactory 里面该怎么写呢?直接 new Printer() ? 太 low 了。还是实现依赖。
最后,你要把这一堆玩意在代码里组装起来,也太难看了,各种 new 实现类。太 low!
好在我们有个高级玩意,叫依赖注入!把程序对象结构全写到配置文件里面。这一套当然是不能自己造轮子的。配置 Spring 吧。搞了那么多 lib,靠命令行或者 IDE 的项目管理肯定不够啊,得有依赖管理。Maven 啊 Gradle 啊使劲上。
最最后,要 print 的东西怎么传给程序呢?硬编码?命令行传参数?太 low!当然得写在 XML 里头。
光是 XML 当然还不够企业级,再加上 DTD 验证吧。
然后就涉及到了 XML 解析的问题了。代码里直接操起 parser 吗?太 low! 当然要写个 parser 的包装类,interface,abstract class,implementation class,factory class 再来一套。毕竟,不能依赖实现啊,以后我要是换 parser 了怎么办。
所以最后是成品是一堆配置文件,一堆 jar,compile 出来的程序 200MB。
IDE 得装上 300 个插件,打开项目硬盘响老半天吃掉 2GB 内存,然后一堆插件弹提示要求升级。
哦对了,在这一切发生之前,还得画 UML 图呢。三年后项目完工了,部署到客户的服务器上一跑,立马崩溃,一地的 stack trace。
原来客户服务器上用的是 JDK 8 而新项目需要 JDK 11。然后问客户你们不能升级吗,答案是不行,因为另外一个企业级开发组给做的企业级解决方案只支持 JDK 8。接着客户把你们的架构师臭骂了一顿,你搞了那么多设计就没有想过可能会换 JDK 吗?
内部 code review,架构师还在洋洋得意的说,我虽然不经常写代码,但我的代码扩展性无人能敌!
会后一堆人在议论,架构师好像少写了单元测试;文档也没有;还有人说架构师的单节点 hello world 挂了怎么办?
得用上微服务,redis,nginx,docker,k8s 等等 devops 。。。
全部得安排上,干着造炮仗的事,操着造核弹的心!