今天看书的时候看到这么一句。“多重循环时,尽量不用 break。”不理解啊,请问为什么?

2015-05-05 17:43:52 +08:00
 leisurelylicht
3112 次点击
所在节点    编程
5 条回复
abscon
2015-05-05 17:59:51 +08:00
因为这句话本身就有问题。关注点不对。
leisurelylicht
2015-05-06 09:50:51 +08:00
@abscon 关注点不对是什么意思?书中的意思应该是在多重循环中不要使用break跳出循环,在书中其它的代码中,跳出循环也多次使用了将for中的判断变量置成一个超范围的值来结束循环。
abscon
2015-05-06 11:46:27 +08:00
打个比方,你要学画画,老师会对你说,画画的时候尽量不用紫色,多使用红色吗?用什么颜色显然取决于被画的东西和你要表达的情感。
再打个比方,你要学中国象棋,老师会对你说,将军的时候尽量用铁门栓,少用马后炮吗?用什么杀招显然取决于棋盘上具体的形势。

语言提供的这些for啊break啊continue啊if啊else啊goto啊什么的(我假设你学的是类C语言),你可以理解成调色板上不同的颜色。

你可以想一下,既然书里面表达了自己的偏好(尽量不用break),那么语言的发明者为何不干脆取消掉break呢?既然留着它,说明某些场合下还是可以合理使用break的。那么就应该说清楚:什么时候应该使用break?什么时候不应该使用break,使用和不使用都有何利弊?而不是在写循环之前就确立一个规则:尽量不用break。这本书这么简单粗暴地教你,引起了你的怀疑和不理解,所以在v2ex上发了这个帖子,这是很合理的怀疑。

而且,对于使用break跳出循环的程序,总可以添加控制变量达到逻辑等价的效果,从而消除break。根据你看到的书里的示范,“尽量不用break”对于你来说其实就是“别用break”。

我写一个循环之前,自己都不知道要用到些什么关键字。是用while还是for?要不要用break,continue和goto?这些我统统都不知道,没有先验的规则。先想明白你此时此刻代码要做的事情的整个流程,就像下棋一样,以一定的原则(比如清晰/高效)反复调整代码,最后事情就这样成了:)——关注点应该在于某一个具体的循环怎么表达才优美简洁效率高,而不是多使用某某表达方式。

------------------------------
上面说的是这本书在教学方式上的错误。接下来说一下它在内容方面的错误。
它之所以提倡别用break,是因为它:
1. 提倡“结构化编程”
2. 认为使用break(还有return,goto)打破了“结构化编程”的“一进一出”原则

在这里我不想说1.和2.都是不对的,我只想说:学术上的争论就留给学者去发论文吧。程序员写程序时不要为了学者制订的一个不确定能带来什么收益的规章制度而扭曲自己的思维。 除非该学者告诉你照他说的做可以形式化验证你程序的正确性。
abscon
2015-05-06 11:58:36 +08:00
@leisurelylicht 呃,漏看了一个“多重”。补充一下吧。

如果这书是关于C/C++的,那么这个话题不存在。因为break只能跳出一重循环的,当然要用其他方式跳出“多重”循环,此时不是你“尽量避免使用break”的问题,而是压根用不上。要想自由飞翔得用goto;

如果这书是关于Java的,break是可以跳出多重循环的。所以这个话题可以存在,只是上贴我说过了,选择这个话题是不恰当的教学方式。
leisurelylicht
2015-05-09 21:53:25 +08:00
@abscon 谢谢的你的详细回答。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/188669

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX