当前位置:首页 > 科技  > 软件

快看,我的代码能“自己说话”!

来源: 责编: 时间:2024-06-05 17:41:57 85观看
导读开发人员什么时候最崩溃?别人我不知道,就我而言,要是我耗费了几个小时来研究代码,试图破译它的目的,却迟迟不得门路,真是恨不得找到写代码的那个家伙,让他回炉重造。今天我们将在这篇文章中探讨如何编写自文档化的代码,让代码

开发人员什么时候最崩溃?7KW28资讯网——每日最新资讯28at.com

别人我不知道,就我而言,要是我耗费了几个小时来研究代码,试图破译它的目的,却迟迟不得门路,真是恨不得找到写代码的那个家伙,让他回炉重造。7KW28资讯网——每日最新资讯28at.com

今天我们将在这篇文章中探讨如何编写自文档化的代码,让代码自己会说话。7KW28资讯网——每日最新资讯28at.com

什么是自文档化的代码?

自文档化的代码是以清晰、富有表现力的方式编写的代码,无需大量的注释和外部文档,就能让人理解代码的目的和功能。7KW28资讯网——每日最新资讯28at.com

自文档化代码的特点:

  • 可读性:代码易于阅读和理解,一目了然
  • 富有表现力:清楚传达代码的意图和目的
  • 可维护:代码易于修改和更新,不会引入错误和重大更改

自文档化代码的重要性

编写自文档化代码的好处:7KW28资讯网——每日最新资讯28at.com

  1. 开发人员可以快速掌握代码的目的和功能,减少理解和使用代码库所需的脑力劳动。
  2. 新的团队成员可以更快地上手,因为他们不需要特别依赖外部文档。
  3. 最大限度地减少团队成员之间的误解,促进对代码库的共同理解。
  4. 即使随着时间的推移,维护和更新也依然方便简单,因为开发人员可以快速理解现有代码并做出明智的更改。

如何编写自文档化的代码

了解了什么样的代码是自文档化的代码之后,敲黑板,我们的重点来了,那么,怎么编写这样可以“自己说话”的代码呢?7KW28资讯网——每日最新资讯28at.com

1.使用有意义的名字

使代码自文档化的最有效方法之一是对变量、函数、类和模块使用有意义的名称。7KW28资讯网——每日最新资讯28at.com

请看以下示例:7KW28资讯网——每日最新资讯28at.com

// Badconst x = 5;const y = 10;const z = x + y;// Goodconst numberOfItems = 5;const itemPrice = 10;const totalCost = numberOfItems * itemPrice;

在Good示例中,变量名称numberOfItems、itemPrice、totalCost清楚地传达了用途,理解起来非常方便。7KW28资讯网——每日最新资讯28at.com

2. 编写小而精的函数

编写小而精的函数是自文档化代码的另一个关键。函数应当功能单一,并准确命名以反映其目的。7KW28资讯网——每日最新资讯28at.com

例如:7KW28资讯网——每日最新资讯28at.com

// Badfunction processData(data: any): any {    // ...    // Lots of complex logic    // ...    return result;}// Goodfunction extractRelevantFields(data: Record<string, any>): Record<string, any> {    // ...    return relevantFields;}function applyBusinessRules(relevantFields: Record<string, any>): Record<string, any> {    // ...    return processedData;}function formatOutput(processedData: Record<string, any>): string {    // ...    return formattedResult;}

通过将大函数分解为名称更具描述性的小而精函数,代码明显更可读了。7KW28资讯网——每日最新资讯28at.com

3. 使用描述性的函数名称和方法名称

在命名函数和方法时,使用描述性的名称可以更加清楚地传达其目的和操作。注意:应尽量避免使用通用名称,如handle()或process()这样的写法。7KW28资讯网——每日最新资讯28at.com

请看示例:7KW28资讯网——每日最新资讯28at.com

// Badfunction handleInput(input: string): void {    // ...}// Goodfunction validateUserCredentials(username: string, password: string): boolean {    // ...}

看到了吗?描述性名称validateUserCredentials清楚地表明了函数的作用。现在,我们哪还需要额外的注释?7KW28资讯网——每日最新资讯28at.com

4. 利用 TypeScript 的类型系统

TypeScript 强大的类型系统可以大大增强代码的自文档化。所以要懂得利用工具,借助 TypeScript 的功能,使代码更具表现力,及早发现潜在的错误。7KW28资讯网——每日最新资讯28at.com

例如:7KW28资讯网——每日最新资讯28at.com

  • 接口和类型:使用接口和自定义类型来定义数据结构的形状。
interface User {    id: number;    name: string;    email: string;}function getUserById(id: number): User | undefined {    // ...}
  • 枚举:利用枚举来表示一组固定的值,提供了一种清晰易读的方式来处理不同的方案。
enum PaymentStatus {    Pending = 'pending',    Completed = 'completed',    Failed = 'failed',}function processPayment(status: PaymentStatus): void {    // ...}
  • 类型推断:尽量使用 TypeScript 推断类型,因为可以精简代码。
// Badconst count: number = 10;const message: string = 'Hello, world!';// Goodconst count = 10;const message = 'Hello, world!';

5. 使用强类型 ID

在 TypeScript 中处理 ID 时,建议使用强类型 ID,不要直接上字符串和数字。强类型 ID 提供了额外的类型安全性。7KW28资讯网——每日最新资讯28at.com

实现强类型 ID 的一种方法是使用不透明的类型:7KW28资讯网——每日最新资讯28at.com

// user.tsexport type UserId = string & { readonly __brand: unique symbol };export function createUserId(id: string): UserId {    return id as UserId;}// post.tsexport type PostId = string & { readonly __brand: unique symbol };export function createPostId(id: string): PostId {    return id as PostId;}

这里我们使用强类型 ID,确保了UserId只分配给需要UserId的属性和函数,PostId只分配给需要PostId的属性和函数。7KW28资讯网——每日最新资讯28at.com

function getUserById(userId: UserId): User | undefined {    // ...}const userId = createUserId('user-123');const postId = createPostId('post-456');getUserById(userId); // No errorgetUserById(postId); // Error: Argument of type 'PostId' is not assignable to parameter of type 'UserId'.

强类型的 ID 有助于在编译时捕获潜在错误,使代码更具表现力和自文档化。7KW28资讯网——每日最新资讯28at.com

但是,与使用简单的字符串类型相比,强类型 ID确实会引入一些开销。所以我们需要根据项目的需求和规模权衡利弊。7KW28资讯网——每日最新资讯28at.com

6. 增强团队凝聚力

团队工作的时候,建立一致性至关重要,不然你有你的标准,我有我的约定,程序还怎么跑得起来?7KW28资讯网——每日最新资讯28at.com

关于一致性,有一个非常重要的方面是命名约定。最好的做法是建立一个风格指南,定义变量、函数、类和其他实体的命名方式。7KW28资讯网——每日最新资讯28at.com

例如,可以使用类似这样的术语:7KW28资讯网——每日最新资讯28at.com

  • get:检索 API 或数据源中的单个值。
  • list:检索 API 或数据源中的一组值。
  • patch:部分更新现有实体和对象。
  • upsert:更新现有实体,如果不存在,则插入新实体。

统一执行术语可以确保整个代码库的一致性。7KW28资讯网——每日最新资讯28at.com

例如:7KW28资讯网——每日最新资讯28at.com

function getUser(userId: UserId): Promise<User> {    // ...}function listUsers(): Promise<User[]> {    // ...}function patchUser(userId: UserId, updatedData: Partial<User>): Promise<User> {    // ...}

怎么样,是不是明显更易于大家理解了呢。7KW28资讯网——每日最新资讯28at.com

除了命名约定之外,还可以为代码库的其他方面制定准则,例如文件和文件夹结构、注释、错误处理、测试和代码格式等。7KW28资讯网——每日最新资讯28at.com

在团队中工作时,我们有时候可能不习惯或者不赞同正在执行的某个约定。但是,重要的是要记住,一致性和协作对于项目的成功至关重要。7KW28资讯网——每日最新资讯28at.com

即使你有不同的偏好或编码风格,也应该遵守约定。从而保持一个有凝聚力的代码库,减少混淆。7KW28资讯网——每日最新资讯28at.com

7. 复杂场景使用 JSDoc 或 TSDoc

虽然自文档化的代码非常优秀,但是不可否认的是,在某些情况下该上文档就得上文档,例如如果遇到复杂的算法和复杂的业务逻辑,你不写注释,简直就不给后来人活路。7KW28资讯网——每日最新资讯28at.com

在这种情况下,可以考虑使用 JSDoc 或 TSDoc 来提供清晰简洁的文档。7KW28资讯网——每日最新资讯28at.com

/** * Calculates the Fibonacci number at the given position. * * @param {number} position - The position of the Fibonacci number to calculate. * @returns {number} The Fibonacci number at the specified position. */function fibonacci(position: number): number {    if (position <= 1) {        return position;    }    return fibonacci(position - 1) + fibonacci(position - 2);}

通过 JSDoc 或 TSDoc,我们可以为复杂的代码提供额外的上下文和说明,而不会使代码库变得乱糟糟。7KW28资讯网——每日最新资讯28at.com

结论

编写自文档化的代码是每个开发人员都应该努力掌握的一门艺术。7KW28资讯网——每日最新资讯28at.com

通过有意义的名称、小而精的函数、 TypeScript 的类型系统以及明智地使用文档,我们可以创建可读的、富有表现力的和可维护的代码。7KW28资讯网——每日最新资讯28at.com

自文档化的代码,可以减少对外部文档的依赖,使我们的开发工作更轻松。7KW28资讯网——每日最新资讯28at.com

所以,下次写代码的时候,花点时间考虑如何使其更具自文档性。相信我,未来的你自己和队友都会感谢你!听我说,谢谢你,因为有你,温暖了四季。7KW28资讯网——每日最新资讯28at.com

本文链接://www.dmpip.com//www.dmpip.com/showinfo-26-92117-0.html快看,我的代码能“自己说话”!

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 被严重低估!React 19 又是一次开发方式的变革,useEffect 将会逐渐退出历史舞台

下一篇: 一个开源且全面的C#算法实战教程

标签:
  • 热门焦点
  • 三言两语说透设计模式的艺术-简单工厂模式

    三言两语说透设计模式的艺术-简单工厂模式

    一、写在前面工厂模式是最常见的一种创建型设计模式,通常说的工厂模式指的是工厂方法模式,是使用频率最高的工厂模式。简单工厂模式又称为静态工厂方法模式,不属于GoF 23种设计
  • 把LangChain跑起来的三个方法

    把LangChain跑起来的三个方法

    使用LangChain开发LLM应用时,需要机器进行GLM部署,好多同学第一步就被劝退了,那么如何绕过这个步骤先学习LLM模型的应用,对Langchain进行快速上手?本片讲解3个把LangChain跑起来
  • 在线图片编辑器,支持PSD解析、AI抠图等

    在线图片编辑器,支持PSD解析、AI抠图等

    自从我上次分享一个人开发仿造稿定设计的图片编辑器到现在,不知不觉已过去一年时间了,期间我经历了裁员失业、面试找工作碰壁,寒冬下一直没有很好地履行计划.....这些就放在日
  • 一个注解实现接口幂等,这样才优雅!

    一个注解实现接口幂等,这样才优雅!

    场景码猿慢病云管理系统中其实高并发的场景不是很多,没有必要每个接口都去考虑并发高的场景,比如添加住院患者的这个接口,具体的业务代码就不贴了,业务伪代码如下:图片上述代码有
  • 一条抖音4亿人围观 ! 这家MCN比无忧传媒还野

    一条抖音4亿人围观 ! 这家MCN比无忧传媒还野

    作者:Hiu 来源:互联网品牌官01 擦边少女空降热搜,幕后推手曝光被网友誉为&ldquo;纯欲天花板&rdquo;的女网红井川里予,近期因为一组哥特风照片登上热搜,引发了一场互联网世界关于
  • 华为Mate60标准版细节曝光:经典星环相机模组回归

    华为Mate60标准版细节曝光:经典星环相机模组回归

    这段时间以来,关于华为新旗舰的爆料日渐密集。据此前多方爆料,今年华为将开始恢复一年双旗舰战略,除上半年推出的P60系列外,往年下半年的Mate系列也将
  • iQOO 11S评测:行业唯一的200W标准版旗舰

    iQOO 11S评测:行业唯一的200W标准版旗舰

    【Techweb评测】去年底,iQOO推出了“电竞旗舰”iQOO 11系列,作为一款性能强机,该机不仅全球首发2K 144Hz E6全感屏,搭载了第二代骁龙8平台及144Hz电竞
  • iQOO Neo8 Pro即将开售:到手价3099元起 安卓性能最强旗舰

    iQOO Neo8 Pro即将开售:到手价3099元起 安卓性能最强旗舰

    5月23日,iQOO如期举行了新品发布会,全新的iQOO Neo8系列也正式与大家见面,包含iQOO Neo8和iQOO Neo8 Pro两个版本,其中标准版搭载高通骁龙8+,而Pro版更
  • OPPO K11样张首曝:千元机影像“卷”得真不错!

    OPPO K11样张首曝:千元机影像“卷”得真不错!

    一直以来,OPPO K系列机型都保持着较为均衡的产品体验,历来都是2K价位的明星机型,去年推出的OPPO K10和OPPO K10 Pro两款机型凭借各自的出色配置,堪称有
Top
Baidu
map