程序设计之美

前言

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

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

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

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

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

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

原则

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

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

解耦

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

规范

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

程序设计六大原则

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

总结

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

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

相关推荐
阿星智力囊17 分钟前
Thinkphp6+nginx环境报错信息不显示,接口直接报500和CORS跨域(错误的引导方向),真坑啊
运维·nginx·php·thinkphp6
y***54882 小时前
PHP框架设计模式
设计模式
Xudde.3 小时前
Quick2靶机渗透
笔记·学习·安全·web安全·php
F***c3254 小时前
PHP在微服务中的分布式跟踪
分布式·微服务·php
口袋物联5 小时前
设计模式之适配器模式在 C 语言中的应用(含 Linux 内核实例)
c语言·设计模式·适配器模式
MobotStone5 小时前
大数据:我们是否在犯一个大错误?
设计模式·架构
chxii5 小时前
PHP 配置全解析:Apache vs Nginx 的线程安全差异与 Windows 实战指南
运维·php
用户607320369456 小时前
PHP cURL 接口调不通?最全故障排查流程来了(新手必收藏)
php
q***72197 小时前
PHP使用Redis实战实录2:Redis扩展方法和PHP连接Redis的多种方案
开发语言·redis·php
7***n757 小时前
前端设计模式详解
前端·设计模式·状态模式