程序设计之美

前言

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

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

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

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

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

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

原则

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

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

解耦

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

规范

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

程序设计六大原则

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

总结

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

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

相关推荐
浩风祭月1 小时前
我用 AI 辅助重构了遗留项目的认证模块:从明文存储到 OAuth 2.0 的安全升级
后端·php·ai编程
qq_297574671 小时前
设计模式系列文章(基础篇第22篇):访问者模式——分离数据结构与操作,实现灵活扩展
数据结构·设计模式·访问者模式
宋拾壹2 小时前
fastadmin列表中查看列表,并且添加增加相应的数据
javascript·php·fastadmin
weixin_446260852 小时前
LLM智能体在社交模拟中的决策行为分析:有限状态与LLM-based策略对比研究
开发语言·php
唐青枫4 小时前
Php Doctrine ORM 实战详解:从实体映射到查询、关联与事务
php·symfony
一直奔跑在路上5 小时前
深入浅出RDMA:原理、应用与实战指南
开发语言·php
右耳朵猫AI6 小时前
PHP周刊2026W23 | Composer 2.10、Symfony 8.1、Twig 3.27.1、PHP 8.5、Laravel AI SDK
php·composer·symfony
刀法如飞9 小时前
领域驱动 vs 本体驱动:DDD 代码建模与 Ontology 语义建模的对比分析
设计模式·架构设计·领域驱动
2401_8346369917 小时前
Nginx 从入门到实战:静态 / 动态站点、PHP 部署与反向代理全解析
运维·nginx·php