一个文件(或函数)代码很长是严重的问题吗?

2011-04-02 10:24:03 +08:00
 virushuo
从 @newblue 给 @livid 的意见 http://www.v2ex.com/t/10859 而起,觉得这问题可以讨论。

我认为“代码过长是不好的变成习惯”的说法已经过时了。在过去编辑器不够发达,语言能力不够强的时候,一个函数中过长的代码确实难以维护和调试。但现在已经有很多足够好的编辑器和IDE,并不会感觉到麻烦。

比如Xcode支持的 #pragma mark ,就算一个.m文件再长,只要有打这种mark的良好习惯,都会容易组织代码,维护并不困难。

调试也一样,如果直接用gdb调试,过长的函数也很麻烦。但现在有了更多的静态和动态分析方法,很多时候不需要再用gdb一行一行的调代码了。(动态语言就更没这麻烦了)

而文件太多,要在文件之间来回跳来跳去,反而不如 #pragma mark 这种标记容易使用。

所以我认为以代码长已经可以看作一种编程风格,而不是一种坏习惯。当然代码逻辑混乱,另当别论。

大家的看法呢?
6688 次点击
所在节点    问与答
27 条回复
newblue
2011-04-02 10:31:54 +08:00
如果一段代码其中某些部分可以独立开来的话,把可以重用的部分抽出来,是一个比较好的处理方法。

像Python这种靠缩进确定代码块的语言,不合适台长的代码块。这是修改v2ex的体会。
crazycookie
2011-04-02 10:33:06 +08:00
只要这个文件或者函数是相对独立的,他里面的很多操作原子 只有它本身使用的,我觉得再长都无所谓,只要配上详细的注释 很多功能函数本来就是复杂的东西
曾经见过 一个函数一页多,头部注释两页的函数一枚,是复杂的算法函数
virushuo
2011-04-02 10:34:56 +08:00
@newblue 是说错进层次太多吗?那个倒确实很头疼。
dreamer
2011-04-02 10:35:51 +08:00
我觉得一个函数的代码太长会不太舒服,如果里面再包含很多的 if else, switch case 就有点儿恐怖了。虽然很多 IDE 对于函数都有很好的代码管理功能,但是我想还有一些人非常喜欢用 TextMate, VIM, Emacs 等编辑器做开发,所以如果一个 if block 里面的代码如果太长,还是建议抽取出来,会使结构更清晰一点。
crazycookie
2011-04-02 10:36:35 +08:00
@newblue 个人觉得 代码好坏的判断依据:不是你修改的难易程度作为依据的。而是你是否能快速的读懂,作者的设计思路是否明确 为依据。 毕竟,代码写完之后 是用来执行 和 应用的 很少有代码是经常性的拿来修改的
dreamer
2011-04-02 10:37:14 +08:00
@newblue python 的缩进如果超过4层,可以想象有多难看。XD
Sai
2011-04-02 10:42:05 +08:00
只要分类清晰,易于开发协作,将同一类函数放一个文件不是什么大问题。

不过我是很有整理癖的人,iOS 的 Project 不仅在 xcodeproj 内要分门别类,就算是 App 实体文件夹我也会按 Views / View Controllers 等等整理。

另外 PHP 的话如果代码都写在一个文件里那么执行的时候那整个文件都需要载入到内存中(比如老 PB 的那种组织形式),执行效率上也许会打折扣。当然在 APC, eAccelerator 的帮助下性能损耗可以忽略不计。

@newblue 指的过长是代码中存在大量的重复代码(比如举例的那个 select 表单),这样的代码是需要抽象成通用函数进行重构的。
newblue
2011-04-02 10:49:22 +08:00
@virushuo
Python这种代码不管缩进的多少,只要太长都会产生严重的问题,中间要是有一行没对齐,都要出问题。

@Sai
不管一段长代码是否春在大量重复的代码,适当的把不属于该段代码的功能的代码独立出来,都是应该的。
以后可以重用到也是一个好处。
leben
2011-04-02 10:55:07 +08:00
今天早上还在想这个问题,有时候看别人的代码,跳来跳去的函数,找函数在哪就是一件很痛苦的事。
keakon
2011-04-02 10:59:07 +08:00
对机器来说,代码长度从来不是问题,但问题是你得给人来读。

假设你按照一份说明书去为你的电脑加硬盘,这份说明书花了10页来告诉你怎么拆第一颗螺丝,又花了10页告诉你怎么拆第二颗…你会不会觉得很无语?
chone
2011-04-02 11:17:52 +08:00
如果是面向过程的话可能还行(不过分清模块的话应该也不是很长),面向对象的话,如果算法不复杂的话,代码过长往往就意味着给某些类塞了太多的东西。至于python缩进的问题,我觉得函数代码长度尽量控制在一屏之内是一种美德。
9hills
2011-04-02 11:21:04 +08:00
http://www.kernel.org/doc/Documentation/CodingStyle
80x24的标准终端上,一到两屏,也就是24~48行。。,例外就是大规模且互不干扰的的switch,

这个标准虽然有人会说是 古老,针对C,不合时宜。。。。
但是一个函数48行,尤其是python这种连{}都没有的语言,大部分情况下就够了
franksin
2011-04-02 11:49:44 +08:00
一个函数如果做了太多的事情,会被后来维护代码的人偷偷BS的吧。。。
virushuo
2011-04-02 11:55:08 +08:00
@9hills 那个我当然知道,但现在的设备早就不是这样了。同时用几个超过21寸显示器都是正常的。
chone
2011-04-02 12:06:07 +08:00
@virushuo 屏幕可以外接,人脑可不能,一个代码块短小主要是能在逻辑上显得更清晰。
iwinux
2011-04-02 12:09:42 +08:00
@virushuo 从测试的角度来看,与一个很长的函数相比,一堆短小的函数比较容易做单元测试。
clowwindy
2011-04-02 12:15:00 +08:00
代码长度有时更多的暗示着设计问题。就我自己来说,一般一个类到了一千行的时候,会感到一种bad smell,这时就开始考虑按照方面来拆分这个类了。
可读性方面,我觉得这个受编辑器的影响很大,比方说eclipse里习惯了ctrl+O以后,很少就会用拖滚动条来定位函数了,而对于没有定位功能的编辑器来说,函数过多就成了一个灾难。
dreampuf
2011-04-02 14:11:22 +08:00
除非有绝对的拓展必要..
否则用空行来区分逻辑..不拆分文件.

vimer.


以前用维修死丢丢写C#时.
一个类往往就一行代码起作用.
Platinum
2011-04-02 14:36:52 +08:00
这个问题真的是 virushuo 问的么……

如果程序的运行结果跟我想的完全不一样,我不会认为是编译器错了,一定是我错了

如果一个函数有 200 行,我会认为一定是我写错了,而不是对行数的要求过时了

如果缩进有 5 层,我会去寻找一定有哪里可以缩减层数,而不是在编辑器里设置一个缩进=2空格

上述情况也许真的有例外,但我会忽略掉,假设例外的不存在,就像假设 md5 不会碰撞一样
Kymair
2011-04-02 15:01:37 +08:00
我还是觉得函数过长是肯定有问题的,除了少数为了优化性能的极端情况。

函数提供的不仅是语义上的区分,还有更重要的实际信息隐藏用途。举个例子,将本应抽取成几个函数的语句放到一个里面,如果用i当counter做了循环,那么下文再次用到循环时就只有两个选择:换一个变量j,或者重用i之前确保它被还原成了初始值。这无疑是把机器应该做的事情推给了程序员。也许你说,现在大多用foreach或iterator或block之类,但这里只是一个例子,一个大函数,需要程序员小心翼翼的控制所有visible的变量的访问,而这本来是可以用函数来隐藏的。

即使单从程序员理解角度上来讲,一个函数跟一个mark对比,都有一个名字,但多提供了输入参数和返回值的信息,返回值到输入参数的映射,这是函数的本质含义。

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

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

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

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

© 2021 V2EX