例程,程序,方法 - 无论你怎么称呼它们,它们都是我们开发人员的重要组成部分。您评价最重要的一个特征是什么?
(通过为每个答案提供一个特征,可以单独投票。也就是说,这个问题的目的不是决定挑出一个特征,而是强调所有重要的。)
答案 0 :(得分:16)
我认为最重要的标准是它有一个目的。
之后,它正确地满足了这个目的(并且只有那个目的)。
答案 1 :(得分:8)
自评程序名称。
实施例: GetStoreFromAddress GetCarsByMake
答案 2 :(得分:4)
它应该很容易进行单元测试。
答案 3 :(得分:4)
例程的名称一对一映射到它的功能。
令人惊讶的是,函数X经常X和X,或X的大部分而不是X的全部。
答案 4 :(得分:4)
没有单一的标准来区分好的例程和坏例程。
中的标准是:
答案 5 :(得分:3)
旨在让人们轻松阅读和理解 - 如果不是这样,修改它以获得将在此处列出的所有其他精彩属性更加困难
答案 6 :(得分:3)
尝试做的事情。
如果这不是1,那么你可能有问题。
答案 7 :(得分:3)
它不应该有意想不到的副作用。
答案 8 :(得分:2)
简洁
(这应该是一个半有趣的答案,但是不要让它自己发布单词!)
答案 9 :(得分:2)
良好的错误处理(可靠性)
答案 10 :(得分:1)
代码行。
答案 11 :(得分:1)
我会说有很好的记录(并且实际强制执行)前后条件。
答案 12 :(得分:1)
该例程始终使用一致的抽象级别。
答案 13 :(得分:1)
从例程名称,您可以说出例程的作用(当您检查代码时,您意识到您是对的; - )
答案 14 :(得分:1)
如果您将例程视为API的一部分,我认为这更容易解答。没有多少例程是独立的,至少不是真正有用的系统。老实说,我认为在编写例程时要考虑的最重要的事情是:
直觉性我的说明书是多么直观 - 人们是否能够理解目的而无需通过大量文档?
Orthogonality 我的例程如何正交?每个完成一项特定任务,还是有多种(但略有不同)的方法来做同样的事情?如果有,这很糟糕,API可能需要重新设计。
紧凑性完成简单任务需要多少API?我是否需要学习很多东西才能完成某些工作,或者我只需要做一些直观而强大的例程即可满足要求?你需要权衡这个与正交性的权衡,以便为你的特定领域取得良好的平衡。
答案 15 :(得分:1)
清晰度 - 易于理解
答案 16 :(得分:1)
它做一件事或将多件事委托给其他职能
答案 17 :(得分:1)
您应该跟踪例程投入使用后所需的编辑次数。 “好”例程是需要很少编辑的例程。当需要一堆修复时,一个“坏”例程肯定会证明是这样的。
这可以通过在每次编辑后更新的每个方法调用上的注释标题轻松完成。
答案 18 :(得分:1)
必须是原子的
答案 19 :(得分:0)
单个返回点