找回密码
 立即注册
CeraNetworksBGVM服务器主机交流会员请立即修改密码Sharktech防护
查看: 233|回复: 0

一文教你如何写出优质代码

[复制链接]

66

主题

24

回帖

696

积分

高级会员

积分
696
发表于 2023-11-5 00:14:34 | 显示全部楼层 |阅读模式
优质代码是什么?
优质代码是指那些易于理解、易于维护、可读性强、结构清晰、没有冗余、运行效率高、可复用性强、稳定性好、可扩展性强的代码。

这类代码不仅能够准确执行预期功能,同时也便于其他开发者理解和修改。

这类代码通常会遵循一定的设计模式和编程规范,拥有清晰的逻辑结构和规范的代码格式,且注释适量且恰当。

优质代码该具备什么条件?
1、轻量级
轻量级的代码主要是指代码的复杂性低,易于理解和维护。

这一般通过减少代码的冗余、提高代码的可读性和可维护性等手段来实现。例如,避免使用过多的嵌套语句,尽可能地使用简单的数据结构和算法,避免使用复杂的编程语言特性等。

2、低耦合(松耦合)
耦合是指代码之间的依赖关系。低耦合或者松耦合的代码是指代码之间的依赖关系尽可能地少,每一部分代码都可以独立地完成其功能。

这样可以使得代码更容易维护和修改,因为修改一部分代码不会影响到其他部分的代码。实现低耦合的方法主要有模块化设计、使用接口或者抽象类来隐藏实现细节等。

3、易替换
易替换的代码是指当需求变更或者出现更好的实现方法时,可以方便地替换掉原来的代码。

这需要代码的设计有良好的扩展性和灵活性,例如,使用接口或者抽象类来定义功能,使用设计模式来组织代码等。

4、易删除
易删除的代码是指当某部分代码不再需要时,可以方便地删除掉,而不会影响到其他部分的代码。

这也需要代码的设计有良好的模块化和低耦合性。此外,还需要有良好的测试覆盖,以确保删除代码后,不会引入新的错误。

如何写出优质代码?
一、制定并遵守编码规范
编码规范是一套预先设定并约定好的编程风格和代码书写规则。

这本规则指南的内容囊括了变量、函数和类的命名方法,空格和缩进的使用,注释的编写方式,以及代码结构的组织等等。其主要目的在于保障代码的一致性和易读性,以便他人能更便捷地阅读和理解代码。

举个例子,Python 社区有一个非常著名的编码规范 PEP 8。PEP 8 对 Python 代码的格式有一系列的规定,比如说,缩进应该使用 4 个空格,不要使用制表符;每行代码的长度不应超过 79 个字符;变量和函数的命名应该全部使用小写字母,并用下划线分隔单词等等。

二、写注释
众所周知,鱼的记忆只有 7 秒钟,而程序员对他们写出代码的功能的记忆只有三天。

如果编程过程中不加以注释,那么在代码完成的那一刻,唯有程序员和上帝清楚其真正功能。三天过后,恐怕只剩上帝明了这段代码的真正含义。

代码注释说白了就是对代码功能和实现逻辑的解释性补充,主要用于增强代码的可读性和可维护性。

它应用的场景十分明确,就是在编程过程中为代码加一个解释说明,方便日后回顾。

然而,注释的质量并不等同于其数量,只有简洁、精准的注释才是高品质代码的标志。过度的注释如同背景噪音,反而会干扰代码理解。因此,适当的注释策略应是仅对代码中的关键部分与复杂逻辑进行注解。

除了其他常规好处,注释还有助于快速查找和理解之前编写的代码,从而提高代码的复用性。

三、使用有意义的命名
命名和注释一样,都是程序员的大难题。

如果说注释考验的是程序员的总结能力,那么命名无疑是在考验程序员丰富的想象力和创造力。我周围有不少心血来潮就会起奇葩名的程序员朋友,想一出是一出。写的时候自我感觉良好,觉得这个名合适或者方便,等到阅读代码时傻了眼,这都什么跟什么,为什么意大利面应该拌 24 号混凝土。

一个好的名字应该能准确地反映出其功能或用途,而不是随意地使用像 list1 或 func1 这样指代不明,看了就懂,下秒就忘的名字。

如果想解决命名这个难题,最好建立自己的命名规则,不论是对内部变量或全局变量,都应让人们能够一目了然其变量含义。

四、避免使用全局变量
全局变量是在程序全局范围内定义的变量,它们可以在程序的任何处被访问和修改。看起来很便利对吧,但如果大量使用全局变量,编程的整个环境会变得复杂且混乱。

首先,全局变量破坏了封装原则。封装是面向对象编程的一个重要原则,它隐藏了对象的内部细节以保护外部环境。全局变量可以在任何地方被修改,这使得追踪和理解代码流程变得困难。这意味着你需要记住全局变量的状态,并理解在程序的哪个部分会改变它。

其次,全局变量导致函数之间产生隐含的耦合性。这意味着一个函数的行为可能依赖于另一个完全不相关的函数是否修改了全局变量。代码便变得难以理解和预测。

最后,全局变量可能导致命名冲突。如果你在不同的地方使用相同的全局变量名,你可能会意外地覆盖全局变量的值。

相比之下,使用局部变量和函数参数能使代码更加清晰和可维护。局部变量仅在函数内部存在,因此你不需要关心它们在其他地方如何被使用或修改。函数参数可以明确地指出函数的输入和输出,使得理解和测试函数变得容易。

因此,尽管全局变量在某些情况下可能是必要的,但在大多数情况下,最好尽量避免使用全局变量。如果你需要在多个函数之间共享数据,可以考虑使用函数参数,返回值,或者创建一个包含这些数据的类。这将使你的代码更加清晰,易于理解,更容易进行测试和调试。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|HS2V主机综合交流论坛

GMT+8, 2024-11-15 10:01 , Processed in 0.045231 second(s), 4 queries , Gzip On, Redis On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表