我从这本书(从Python开始,从新手到职业)中读到“重复代码通常被认为是一件坏事”(我不是母语人士,所以我不知道最初是怎么写的),并说:
#===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这样的代码。谢谢~
发布于 2017-03-31 14:32:04
第二个例子在两个地方执行读取操作。所以.
假设您编写了这段代码,并且在将来的某个时候,您更改了读取数据的方式;也许现在您希望通过网络读取数据,而不是从文件中读取,或者您希望使用不同的函数从文件中读取数据。在第一个例子中,您只需在一个地方更改"file.read(1)“,而在第二个示例中,您只需在两个地方更改”(1)“,您可能会错过其中一个,或者出错等等。
类似地,您可能会在代码中发现一个bug,并且只在两个位置中的一个中意外地修复它。
这显然是一个简化的例子,它并不重要,但在现实世界的程序中,这样的错误很容易出错:想象一下,它不是一行,而是50行重复代码,有人在一个副本中修复了一个错误,而在另一个副本中却没有。您现在遇到了一个很难调试的问题!
https://stackoverflow.com/questions/43142932
复制相似问题