程序设计之美

前言

世界有各种各样的美,有风景之美;人文之美;文化之美。

那么我们程序开发中的美学是什么呢?

我的理解是规则之美,严谨的程序设计,会使代码结构层次分明,便于开发及维护。

我认为一个业务流程的实现,应该是由多个小功能组装而成。

一个简单的举例:一次下单(商品购买操作)

牵涉的服务有商品中心,订单中心,用户中心,日志中心等,每个服务中心为完成这个业务提供与自己相关的子功能,业务由订单中心发起,由订单中心调用各中心提供的功能接口完成此业务的实现。

原则

  • 单一职责原则
  • 开闭原则
  • 里氏替换原则
  • 迪米特法则
  • 接口隔离原则
  • 依赖倒置原则

关于每个原则的讲解 php常见的设计模式及六大原则

解耦

  • 各服务中心只需专注于自己的业务,不需要关注其他服务中心的业务。
  • 部分业务的实现可采用队列通知;事件 来进行解耦(如删除一个用户时,由用户中心抛出用户删除事件,其它服务中心(订单;日志;其它服务)监听此事件的发生进行后续的业务处理)

规范

  • 服务中心与服务中心之间的依赖应依赖高层模块(接口),接口一旦定义则表达的功能含义不能改变
  • 变量命名设计规范
  • 目录层次设计规范
  • 功能粒度的实现细化,拆的越细后期越好维护

程序设计六大原则

我个人认为,只要深刻理解了程序设计的六大原则,那么设计的架构再怎么都有一个模样。(即是有某种规律可循,遵照这个规则,可以摸透系统的运行模式)

总结

一切的规则设计模式来源于生活,我们要能通过生活发现新的;有效的;可以解决实际问题的设计模式。

我们要抱着严谨的心态去对待每一个需求。对每个需求的实现进行业务拆分,将拆分出的子功能进行归类(哪些属于用户中心实现,哪些属于订单中心实现,哪些属于日志中心实现),然后分配任务到各服务中心,判断这个业务的主要归属服务中心是谁(如下单归属于订单中心,查看某个商品详情归属商品中心),那么就由此服务中心作为业务发起人调用各服务中心提供的功能接口完成业务的实现。

相关推荐
咖啡八杯1 天前
GoF设计模式——备忘录模式
java·后端·spring·设计模式
槑有老呆1 天前
从 Prompt Engineering 到 Harness Engineering:AI 编程的下一次跃迁
设计模式
HjhIron2 天前
从Prompt到Context:大模型应用开发的范式转移
设计模式·aigc·ai编程
咖啡八杯3 天前
GoF设计模式——中介者模式
java·后端·spring·设计模式
胡萝卜术3 天前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
亦暖筑序4 天前
Java 8老系统Browser Agent实战:三层拦截把AI操作后台变成可审计流程
java·后端·设计模式
青禾网络7 天前
Web 前端如何接入 AI 音效生成:从零到可用的完整方案
人工智能·设计模式
ZJPRENO7 天前
吃透软件开发六大设计原则,告别烂代码
设计模式
咖啡八杯8 天前
GoF设计模式——命令模式
java·设计模式·架构
花椒技术8 天前
HJPusher / HJPlayer SDK 实践:我们为什么把直播推播链路拆成一套可复用能力
设计模式·harmonyos·直播