返回顶部
u

uncle-bob鲍勃清洁法则

Apply Robert C. Martin (Uncle Bob) principles for clean code, SOLID design, and clean architecture. Use when: (1) reviewing or refactoring code for quality, (2) designing modules, classes, or functions, (3) asked to "clean up" or improve code structure, (4) evaluating architectural boundaries, (5) naming things, (6) reducing coupling or increasing cohesion. Triggers on phrases like "clean code", "SOLID", "uncle bob", "clean architecture", "refactor for quality", "code smells", "single responsibi

作者: admin | 来源: ClawHub
源自
ClawHub
版本
V 1.0.0
安全检测
已通过
252
下载量
免费
免费
0
收藏
概述
安装方式
版本历史

uncle-bob

Uncle Bob — 整洁代码与架构原则

在编写、审查或重构代码时应用这些原则。它们不是盲目遵循的规则——请运用判断力,但默认保持整洁。

童子军规则

让代码比你发现时更整洁。每次提交都应改善代码库,哪怕只是微小的改进。

整洁代码基础

命名

  • - 名称应揭示意图。如果名称需要注释,说明名称有问题。
  • 使用可发音、可搜索的名称。避免缩写、单个字母(循环计数器除外)和前缀。
  • 类/类型:名词或名词短语(AccountManager、OrderRepository)。
  • 函数/方法:动词或动词短语(calculateTotal、fetchUser、isValid)。
  • 布尔值:读起来像一个问题(isActive、hasPermission、canExecute)。
  • 避免心理映射。r 不是 URL。请用 url。

函数

  • - 要小。然后更小。一个函数只做一件事
  • 理想情况下有 0-2 个参数。3 个以上是坏味道——提取一个选项对象或重新思考设计。
  • 没有副作用。名为 checkPassword 的函数绝不能同时初始化会话。
  • 命令-查询分离:函数要么执行操作(命令),要么回答问题(查询),不能两者兼有。
  • 不要重复自己(DRY)——但不要过早抽象。三次重复是阈值。
  • 能提取就提取:如果可以提取出有意义的子函数,就去做。

注释

  • - 好的代码是自文档化的。注释是为了弥补代码表达上的不足。
  • 法律声明、信息性说明、澄清意图、警告后果以及 TODO 注释是可以接受的。
  • 删除被注释掉的代码。版本控制系统会记住它们。
  • 永远不要写重复代码功能的注释(在 i++ 前写 // 递增 i)。

格式

  • - 垂直方向:报纸隐喻——高层摘要放在顶部,细节放在下面。
  • 相关函数保持靠近。调用者在上,被调用者在下。
  • 水平方向:避免滚动。保持行长度简短。
  • 团队内一致的格式优于个人偏好。

错误处理

  • - 优先使用异常/Result 类型而非错误码。
  • 不要返回 null。不要传递 null。
  • 在函数的顶层编写 try-catch,不要分散在各处。
  • 错误处理是一件事——处理错误的函数应尽量少做其他事情。
  • 根据调用者的需求定义异常类,而非抛出者的实现。

对象与数据结构

  • - 对象隐藏数据,暴露行为。数据结构暴露数据,没有行为。
  • 不要混用它们。同时拥有公共字段和业务方法的类是最糟糕的。
  • 迪米特法则:一个方法只应调用其自身对象、参数、创建的对象或直接依赖的方法。不要出现 a.getB().getC().doThing()。

SOLID 原则

详细解释和示例请参见 references/solid.md

  • - S — 单一职责:一个类只有一个变更理由。一个角色,一个职责。
  • O — 开闭原则:对扩展开放,对修改关闭。使用多态,而非条件判断。
  • L — 里氏替换:子类型必须能够替换其基类型而不破坏行为。
  • I — 接口隔离:多个特定接口优于一个通用接口。客户端不应依赖它们不用的方法。
  • D — 依赖反转:依赖抽象,而非具体实现。高层模块不应依赖低层模块。

整洁架构

完整架构指南请参见 references/clean-architecture.md

依赖规则

源代码依赖必须指向内部——朝向更高层的策略。

框架与驱动 → 接口适配器 → 用例 → 实体
(外层) (内层)

  • - 实体:企业业务规则,纯领域对象。
  • 用例:应用特定的业务规则(编排实体)。
  • 接口适配器:在用例格式和外部格式之间转换(控制器、展示器、网关)。
  • 框架与驱动:最外层(数据库、Web 框架、UI)。细节。可替换。

关键规则

  • - 内圈中的任何内容都不知道外圈中的任何内容。
  • 跨越边界的数据是简单的 DTO 或值对象——绝不能是框架特定的类型。
  • 数据库是细节。Web 是细节。框架是细节。

组件原则

  • - 共同闭包原则(CCP):一起变更的类应放在一起。
  • 共同复用原则(CRP):不要强迫用户依赖他们不用的东西。
  • 稳定依赖原则:朝着稳定的方向依赖。
  • 稳定抽象原则:稳定的组件应该是抽象的。

代码坏味道(危险信号)

  • - 僵化性:小变更导致其他地方产生连锁变更。
  • 脆弱性:一个地方的变更破坏了不相关的代码。
  • 不可移动性:无法在不拖带其依赖的情况下复用模块。
  • 不必要的复杂性:投机性泛化,过早抽象。
  • 不必要的重复:复制粘贴代码(违反 DRY)。
  • 不透明性:代码难以理解。
  • 长函数、大类、长参数列表、布尔标志、基于类型的 switch/case。

测试(TDD)

  • - TDD 三定律:(1)先编写一个失败的测试。(2)只编写足够让测试失败的代码。(3)只编写足够让测试通过的 production 代码。
  • 测试是一等代码。保持它们整洁、可读、快速。
  • 每个测试一个断言(指导原则,非教条)。每个测试一个概念。
  • F.I.R.S.T.:快速(Fast)、独立(Independent)、可重复(Repeatable)、自验证(Self-validating)、及时(Timely)。
  • 测试边界,而非实现。测试行为,而非方法。

应用这些原则

在审查或编写代码时,按此顺序检查:

  1. 1. 可读性:别人能在 30 秒内理解吗?
  2. 命名:名称是否揭示了意图?
  3. 函数大小:有什么可以提取的吗?
  4. 单一职责:每个单元是否只有一个变更理由?
  5. 依赖:它们是否指向稳定/抽象的方向?
  6. 耦合:是否有不必要的耦合?
  7. 错误处理:是否整洁且一致?
  8. 测试:是否存在、整洁且测试了行为?

标签

skill ai

通过对话安装

该技能支持在以下平台通过对话安装:

OpenClaw WorkBuddy QClaw Kimi Claude

方式一:安装 SkillHub 和技能

帮我安装 SkillHub 和 uncle-bob-1776162370 技能

方式二:设置 SkillHub 为优先技能安装源

设置 SkillHub 为我的优先技能安装源,然后帮我安装 uncle-bob-1776162370 技能

通过命令行安装

skillhub install uncle-bob-1776162370

下载

⬇ 下载 uncle-bob v1.0.0(免费)

文件大小: 8.47 KB | 发布时间: 2026-4-15 12:20

v1.0.0 最新 2026-4-15 12:20
- Initial release of the uncle-bob skill.
- Provides practical guidance on applying Robert C. Martin’s clean code, SOLID, and clean architecture principles.
- Includes fundamentals such as naming, functions, comments, formatting, error handling, and the distinction between objects and data structures.
- Covers code smells, component design principles, and testing (TDD) best practices.
- Specifies clear triggers for when and how to use these principles.
- Helpful for reviewing, refactoring, designing, and improving code structure and quality.

Archiver·手机版·闲社网·闲社论坛·羊毛社区· 多链控股集团有限公司 · 苏ICP备2025199260号-1

Powered by Discuz! X5.0   © 2024-2025 闲社网·线报更新论坛·羊毛分享社区·http://xianshe.com

p2p_official_large
返回顶部