我从《Beginning Python From Novice to Profession》一书中读到“重复代码通常被认为是一件坏事”(我不是母语人士,所以我不确定它最初是如何写的) ,并说:
#===11-7===
file = open(PATH)
while True:
char = file.read(1)
if not char:
break
print('Processing:', char)
file.close()
优于:
#===11-6===
file = open(PATH)
char = file.read(1)
while char:
print('Processing:', char)
char = file.read(1)
file.close()
因为11-7避免了代码重复。所以我在这里想问:什么是代码重复?事情有那么糟糕吗?
仅仅从 11-6 的角度来看,我没有看到任何缺点,说实话,如果我没有看过这本书,我会更喜欢像 11-6 这样的代码。谢谢~
最佳答案
第二个示例在两个地方执行读取操作。所以——
想象一下,您编写了这段代码,并且在将来的某个时候,您改变了读取数据的方式;也许现在您想通过网络而不是从文件中读取它,或者您想使用不同的函数从文件中读取。在第一个示例中,您只需在一个地方更改“file.read(1)”,而在第二个示例中,您必须在两个地方进行更改,并且您可能会错过其中一个,或者犯错误等。
同样,您可能会发现代码中的错误,并且意外地只在两个位置之一修复它。
这显然是一个简化的示例,这并不重要,但在现实世界的程序中,很容易犯这样的错误:想象它不是一行,而是 50 行重复的代码,并且有人修复了一份副本中的错误,但没有修复另一份副本中的错误。您现在遇到了一个可能非常难以调试的问题!
关于python - 'code repeat'到底是什么,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43142932/