”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 清晰函数名称的力量:干净的代码必不可少

清晰函数名称的力量:干净的代码必不可少

发布于2024-10-31
浏览:620

The Power of Clear Function Names: A Clean Code Essential

在编程世界中,清晰是王道。提高代码可读性和可维护性的最有效方法之一是使用清晰、描述性的函数名称。让我们深入探讨为什么这很重要以及如何在代码中实现此实践。

模糊函数名称的问题

考虑这段代码:

function addToDate(date, month) {
  // ... implementation
}

const date = new Date();

// What exactly is being added here?
addToDate(date, 1);

乍一看,你能看出这个函数是做什么的吗? addToDate 这个名字很模糊。它告诉我们某些内容正在添加到日期中,但是什么?天?几个月?年?这种模糊性迫使读者深入实施以了解其目的,这是低效的并且可能导致误用。

解决方案:描述性函数名称

现在,让我们看一下改进版本:

function addMonthToDate(month, date) {
  // ... implementation
}

const date = new Date();
addMonthToDate(1, date);

区别很明显(双关语)。 addMonthToDate 明确说明了该函数的作用。它为日期添加了一个月。没有歧义,无需检查实现即可了解其基本目的。

为什么这很重要

  1. 可读性:清晰的函数名称使您的代码自我记录。新的团队成员或未来的你无需深入了解细节即可理解代码的意图。

  2. 可维护性:当功能明确说明其目的时,在需求发生变化时更容易确定需要进行更改的位置。

  3. 减少认知负荷:开发人员可以专注于解决复杂的问题,而不是破译模糊的函数名称。

  4. 更少的错误:清晰的名称可以减少误用的可能性。在我们的示例中,很明显我们添加的是月份,而不是天或年。

编写清晰函数名称的技巧

  1. 具体:使用 getUserById() 代替 get()。
  2. 使用动词:从计算、获取、更新或验证等操作开始。
  3. 避免缩写:除非它们被普遍理解(例如 ID 代表标识符),否则请将其拼写出来。
  4. 保持简洁:在进行描述性的同时,也尽量保持名称相当简短。
  5. 保持一致:在整个项目中坚持命名约定。

结论

花时间设计清晰、描述性的函数名称是一项很小的投资,但可以在代码质量方面带来巨大的回报。这是编写干净、可维护的代码的一个基本方面,你的同事(以及未来的你)会欣赏的。

记住:代码的阅读次数远多于编写次数。让阅读成为一种乐趣!

版本声明 本文转载于:https://dev.to/56_kode/the-power-of-clear-function-names-a-clean-code-essential-12l2?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 理解后端开发中的责任链设计模式
    理解后端开发中的责任链设计模式
    责任链 (CoR) 设计模式是一种强大的行为模式,可以显着增强后端开发。此模式允许您通过处理程序链传递请求,其中每个处理程序可以处理请求或将其传递到下一个处理程序。在本博客中,我们将从后端角度探讨 CoR 模式,特别关注其在 Web 服务中的请求验证和处理中的应用,并使用 Java 作为示例。 ...
    编程 发布于2024-11-08
  • 深入研究&#项目:大学信息查询系统&# - 掌握 Java 和 MySQL 进行高效数据管理
    深入研究&#项目:大学信息查询系统&# - 掌握 Java 和 MySQL 进行高效数据管理
    通过“项目:大学信息查询系统”释放数据管理的力量 - 这是一门综合课程,指导您完成使用 Java 和 MySQL 构建强大的信息查询系统的过程。这种基于项目的学习体验旨在让您掌握将 Java 应用程序连接到 MySQL 数据库、执行 SQL 查询和有效检索数据所需的基本技能。 课程概...
    编程 发布于2024-11-08
  • 使用 PHP 和 JavaScript 将网页下载为 PDF
    使用 PHP 和 JavaScript 将网页下载为 PDF
    在 PHP 中将 HTML 转换为 PDF 很容易。让我们更进一步,使用 PHP 和 JavaScript 将网页转换为 PDF 文件。 为此,您需要安装 Composer 和 Node。 安装完这些东西后,您需要使用 Composer 安装 Dompdf,并使用 npm(Node 包管理器)安装...
    编程 发布于2024-11-08
  • 4 年内构建 AI 代理的顶级框架
    4 年内构建 AI 代理的顶级框架
    Hola,我是 Nomadev!如果您像我一样,您可能已经注意到人工智能代理正在席卷世界。说真的,人工智能代理不仅仅是炒作,它们已经在为智能系统提供动力、自动化任务并代表企业做出决策。我一直在深入研究这个领域,相信我,未来是由代理驱动的。 现在,如果您想成为这场革命的一部分并构建自己的人工智能代理...
    编程 发布于2024-11-08
  • 每个开发人员都应该了解的基本 Express 请求属性
    每个开发人员都应该了解的基本 Express 请求属性
    在项目后端工作时,处理请求和响应至关重要。有效管理这些请求对于客户端和服务器之间的顺利通信至关重要。以下是每个开发人员都应该熟悉的一些常见且重要的请求属性。 1. 请求ip Express.js 中的 req.ip 是请求对象的一个​​属性,它提供发出请求的客户端的 IP 地址。它返...
    编程 发布于2024-11-08
  • 如何解决 Doctrine 左连接期间的“Expected Doctrine\\ORM\\Query\\Lexer::T_WITH, got 'ON'\”错误?
    如何解决 Doctrine 左连接期间的“Expected Doctrine\\ORM\\Query\\Lexer::T_WITH, got 'ON'\”错误?
    如何在 Doctrine 中执行左连接当使用复杂的数据模型时,有必要通过建立多个表之间的关系来从多个表中检索数据。左连接允许您从一个表中获取所有行,并且仅从另一表中获取匹配的行。遇到的问题在 Doctrine 中尝试左连接时可能出现的常见错误正在接收以下语法错误:[Syntax Error] lin...
    编程 发布于2024-11-08
  • 使用 Java/ColdFusion/CFML 比较语言检测库(和 API)
    使用 Java/ColdFusion/CFML 比较语言检测库(和 API)
    语言检测是我们在过去的项目中需要的一个功能。 我在 2020 年写了一篇关于 Optimaize Language Detector java 库的 kju2 fork 的使用的文章。 Optimaize 库自 2015 年以来就没有更新过,kju2 分支于 2023 年 4 月 16 日被置于只...
    编程 发布于2024-11-08
  • 如何在 CSS 中在背景上创建曲线?
    如何在 CSS 中在背景上创建曲线?
    在背景上创建曲线在网页开发领域,设计师经常会遇到出于审美目的创建曲线的需要。其中一个场景是将剪切曲线放置在背景顶部,而不是右侧。要实现这一点,需要修改现有的 CSS 代码来调整曲线的位置和形状。操作方法如下:调整伪元素位置:更改伪元素的位置(.box:之前和 .box:after) 到底部:100%...
    编程 发布于2024-11-08
  • 捕获 Django 应用程序中的错误的最佳方法
    捕获 Django 应用程序中的错误的最佳方法
    在 Web 开发的世界中,错误是整个过程中不可避免的一部分。但对于 Django(最流行的 Python Web 框架之一)来说,拥有可靠的错误捕获策略可以在流畅的用户体验和令人沮丧的用户体验之间产生巨大的差异。 作为开发人员,我们经常发现自己不断地与难以捉摸的错误和意外行为作斗争。无论您是构建小...
    编程 发布于2024-11-08
  • 如何将 GORM 字段注释集成到 Protobuf 定义中?
    如何将 GORM 字段注释集成到 Protobuf 定义中?
    将字段注释集成到 Protobuf 定义中寻求在其 protobuf 定义中使用 GORM 提供的字段注释的开发人员可能会因缺少字段注释而遇到挑战Protobuf 3 语法中的本机日期时间类型。为了解决这个问题,可以使用后处理脚本来使用所需的 GORM 注释来增强生成的原型文件。例如,给定以下 pr...
    编程 发布于2024-11-08
  • 开发人员如何构建实时 Web 应用程序?
    开发人员如何构建实时 Web 应用程序?
    在不断发展的技术世界中,实时 Web 应用程序已成为寻求增强用户参与度和简化沟通的企业的强大解决方案。这些应用程序提供即时更新和交互,使其在消息传递、游戏和电子商务等领域至关重要。对于开发人员,特别是那些在澳大利亚开发人员来说,了解构建实时应用程序的细微差别至关重要。本文将探讨创建实时 Web 应用...
    编程 发布于2024-11-08
  • 使用 SAM 框架构建 Go Serverless REST API 并部署到 AWS (Amazon Linux untime)
    使用 SAM 框架构建 Go Serverless REST API 并部署到 AWS (Amazon Linux untime)
    为什么还要另一个 Go 教程 AWS 最近已弃用多项服务和运行时。正如我们所看到的,随着我们喜爱的 CodeCommit 和其他关键服务的终止,AWS Lambda 函数不再支持 Go1.x。 如果您尝试部署大部分过时的教程,您可能会遇到如下错误: Resource creatio...
    编程 发布于2024-11-08
  • C 中的不相交联合
    C 中的不相交联合
    目前还不清楚如何在 C: 中表达此 Haskell 类型 data Tree = Leaf Int | Inner Tree Tree 与 Haskell 和 Rust 等语言不同,C 缺乏对的内置支持 不相交联合。然而,如果我们愿意做一些额外的输入,它确实提供了代表它们所需的所有成分。 首先要认识...
    编程 发布于2024-11-08
  • 社交媒体上的图文帖子有何作用?
    社交媒体上的图文帖子有何作用?
    图形帖子通过提高用户参与度和强化品牌形象在社交媒体营销中发挥着至关重要的作用。在 Instagram、LinkedIn 和 Facebook 等快节奏的社交平台中,用户滚动浏览大量内容,引人注目的视觉效果可以让您的帖子脱颖而出。图形快速有效地传达信息,使其成为与受众沟通的强大工具。 ...
    编程 发布于2024-11-08
  • 如何使用 javac、Ant 或 Maven 递归编译多个 Java 文件?
    如何使用 javac、Ant 或 Maven 递归编译多个 Java 文件?
    如何使用 javac 递归编译所有 Java 文件为每个包使用单独的 shell 命令编译分布在多个包中的大量 Java 文件可能会很乏味包裹。相反,请考虑使用以下方法之一来简化编译。方法 1:使用 @source生成一个文本文件(例如,sources.txt) txt),其中列出了要编译的所有 J...
    编程 发布于2024-11-08

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3