图标
创作项目友邻自述归档留言

聊聊写框架

前言

不知不觉应该已经折腾了 8 个月的框架了,感觉已经无法在从写框架中获取有趣的知识了。于是就打算写一篇文章,算是对经验的总结。后续可能会开一个从零实现 Java 框架的文章 🤣,使劲挖坑不填坑。

学的越多,了解的越深入,就越感觉自己懂的部分原来是那么小。

初心

说起当初写框架的原因其实挺简单的,无非是想写一个轻量的博客系统代替现在使用的 WordPress,然后因为不想只停留在业务层,于是打算自己写个框架,然后在这个框架上写个博客系统,来以此达到学习和熟悉对应语言的目的。后来框架写着写着就逐渐忘掉了博客系统 🤣。

吐槽

框架,那是最有用的技术,那是最没用的技术。曾经我也因会使用某个框架为荣,因此迷失了学习的目的,同时也浪费了大量的时间。

框架,是构建在底层上的抽象层,不同的框架有不同的抽象逻辑。一旦学习过的框架凉了,那么在框架上花的时间就浪费了。当然我并不是吐槽不能学习框架,而是不应局限于学习框架的应用。当然也不能因为要学习框架的运作原理而去啃源码。通过文档去理解抽象模型才是更好的做法,也就是学习框架使用的思想等“软”技术。正如 Stop Learning Frameworks 这篇文章所说:

编程语言是不同的,但是设计是类似的。

框架是不同的,但是设计模式是类似的。

开发者是不同的,但是如何和这些人打交道是不变的。

设计

**注:**以下的内容均基于 XK-Java,XK-PHP 已暂时不管了 2333。

罗马不是一天建成的,写框架也一样,我们不可能一上手就设计出相对完整的框架系统,所以我们应从小的模块开始实现,如 IoC 容器,路由等,然后扩展其他模块。XK-Java 也是不断经过重构、改进才有了现在相对完善的框架。

XK-Java 早期采用的是采用写死流程的方式来启动,通过一个个 Provider 来对内置的服务进行注册和实例化,这样极其不方便,而且对扩展并不友好。并且随着注解数量的增加,为每个注解都写一个注解处理器并不是优雅的解决方案。于是参考了 Spring 的方式,通过实现组合注解,来完成注解的复用。于是你便可以看到现在 XK-Java 的注解已经累积到了 80 个,而我并不需要为这 80 个注解都编写注解处理器(逃。同时也因为组合注解,后续组件和服务解耦变得容易实现。具体前往 README 这里就不详细说明了,不然文章就会变得又臭又长。

XK-Java 当前的框架启动流程吧,请求流程就留到后续系列文章吧:

结语

写这篇文章写了一个月,因为 10 月和 11 月的一堆事情,所以没写完。今天闲的慌总算写完了,写的乱糟糟的 2333。

聊聊写框架

https://blog.ixk.me/post/talk-about-writing-framework
  • 许可协议

    BY-NC-SA

  • 本文作者

    Otstar Lin

  • 发布于

    2020/11/10

转载或引用本文时请遵守许可协议,注明出处、不得用于商业用途!

浅谈可扩展线程池聊聊现状-[2020-09]