- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我们目前有 3 个开发人员,其中一些开发人员的风格相互冲突,我正在寻找一种方法来为王国带来和平...
程序员:
Foo 1:喜欢使用 Func 和 Action 的内部公共(public)方法。他使用 actions 来避免冗长的方法调用,并使用 Func 来执行简单的任务,这些任务可以用 1 或 2 行来表达,并且将在整个代码中频繁使用
优点:他的代码主体简洁且可读性强,通常每个类只有一两个公共(public)方法,很少有私有(private)方法。
缺点:方法的开头包含其他开发人员不喜欢阅读的富含 lambda 的代码块;有时,可以包含其他开发人员真的不喜欢阅读的高阶函数。
Foo 2:喜欢为(几乎)公共(public)方法必须做的所有事情创建一个私有(private)方法。
优点:公共(public)方法仍然很小且可读(对所有开发人员而言)。
缺点:私有(private)方法很多。使用调用其他私有(private)方法的私有(private)方法,调用...等等,等等。使代码难以导航。
Foo 3: 喜欢为每个需要执行的重要任务创建一个带有单一公共(public)方法的公共(public)类,然后将它们依赖注入(inject)到其他对象中。
优点:易于测试、易于理解(一个对象,一项责任)。
缺点:项目中充满了类,打开多个类文件以了解代码的作用会使导航变得笨拙。
如果能够充分利用所有这些技术,那就太好了……
Foo-1 有非常好的、可读的(几乎是类似 dsl 的)代码……在大多数情况下,除了在方法开始时聚集在一起的所有 Action 和 Func lambda 恶作剧。
Foo-3 具有高度可测试和可扩展的代码,对于某些解决方案来说感觉有点“束缚”并且有一些代码导航问题(在 VS 中不断按 F12 并打开其他 5 个 .cs 文件以找出单一方法的作用)。
还有 Foo-2...嗯,我不确定我是否喜欢这个包含 2 个公共(public)方法和 12 个私有(private)方法的巨大 .cs 文件,除了它更容易让初学者深入研究这一事实。
我承认我过度简化了对这些编码风格的解释;但如果有人知道任何模式、实践或外交策略可以帮助我们的三个开发人员团结起来(而不只是告诉他们中的任何一个“停止它!”),那就太好了。
从可行性的角度来看:
有什么关于一些编码风格或惯例的想法可以使这项工作成功吗?
最佳答案
完全不清楚您为什么不喜欢 Foo-2 的私有(private)方法。
您提示“巨大”的 .cs 文件 - 但为什么它会比 Foo-1 的样式大得多?那里有相同数量的代码,只是操作被拆分为方法而不是表示为 lambda。
老实说,Foo-2 对我来说似乎是最好的选择。将您的公共(public) API 保持在您希望公开的范围内,然后以最简单的方式实现它。虽然 lambda 在某些情况下绝对适用,但 Foo-1 的风格听起来像是把它发挥到了极致——超出了它真正合理的范围。
尤其要考虑您的两个公共(public)方法是否有一些共同的子任务。 Foo-1 的方法最终会复制该代码 - Foo-2 的方法会将公共(public)代码放在一个从两者调用的私有(private)方法中……这对我来说似乎是一种明智的方法。
同样,您谈论的是调用私有(private)方法的私有(private)方法……当然等效的 Foo-1 代码将是调用 lambda 表达式的 lambda 表达式,这几乎没有任何改善!
此外,如果您对白盒单元测试感到满意,Foo-2 的方法可以通过单独测试实现的“较小”位来更轻松地测试“笨拙”的公共(public) API 实现 - 诚然迫使您使用方法的内部可见性而不是私有(private)的,或使用反射。
Foo-3 听起来完全是一种不同的方法,因为它改变了公共(public) API 而不是实现。这更多的是关于设计而不是编码风格,应该单独考虑。
关于c# - 合并编码风格 : Funcs, 私有(private)方法,单一方法类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4571220/
据我所知,在 C# 中,所有字段默认都是私有(private)的,如果没有另外标记的话。 class Foo { private string bar; } class Foo { strin
这个问题在这里已经有了答案: Why is it allowed to access Java private fields via reflection? (7 个答案) 关闭 6 年前。 使用反
在 C#(和许多其他语言)中,访问相同类型的其他实例的私有(private)字段是完全合法的。例如: public class Foo { private bool aBool; pu
使用私有(private)方法通过将一些决策点重构为单独的方法来降低 CC 会降低实际方法的 CC 并易于阅读,但不会减少在测试中获得完整分支覆盖的工作量。 这合理吗?你有什么现场经验? 最佳答案 好
在下面的例子中,模块outer有一个私有(private)类型Private和一个私有(private)内部模块inner。 inner 能够访问Private(因为子模块可以访问其父级的私有(pri
class Person def one @var = 99 self.two end private def two p @var end end p=P
我在 Azure 中创建了 VNET。我放入了一个子集 Azure Private Link,它在 VNET 之外和另一台虚拟机中调用 Azure Function。 当我尝试通过专用 IP 调用专用
我在 Azure 中创建了 VNET。我放入了一个子集 Azure Private Link,它在 VNET 之外和另一台虚拟机中调用 Azure Function。 当我尝试通过专用 IP 调用专用
我正在尝试获得良好的 Ruby 编码风格。为防止意外调用具有相同名称的局部变量,我总是在适当的地方使用 self.。但是现在我偶然发现了这个: class MyClass "method" a
今天遇到一个案例类构造函数的奇怪问题。我想将构造函数设为私有(private),看来这不是问题。所以我已经在我的一个项目中尝试过它并且它有效。但在另一个项目中,我可以调用私有(private)构造函数
我想坚持使用记录,并且不想返回对象。所以我想知道是否可以将记录的字段设置为私有(private)?或者创建记录的私有(private)成员。其他具体类型(例如可区分联合)怎么样? 或者,这个要求是否违
我正在通过 Flickr API 进行经过身份验证的调用来访问照片。但我只得到我的公开照片,而没有任何私有(private)照片。 下面给出的是我正在使用的代码, Flickr f; Request
这两个类的行为不同;原因似乎与使用 private[this] 声明而不是 private 有关。有人可以解释一下为什么吗? 私有(private): class Person( private
在 private 中的 1000 秒 private 之后,我想到可能不需要它 public class Outer { private static class Inner { // yo
我有以下代码: class C { private enum E { // ... } } private extension C { func f(e: E)
OOP 语言中是否有object-private 的概念??我的意思是比经典的私有(private)访问限制更多? Private (or class-private) restricts the a
swift 3.0 我知道fileprivate访问级别修饰符将函数/属性的使用限制在声明它的源文件和 private - 仅限于声明的词法范围。但似乎这条规则不适用于扩展。例如。此代码有效: cla
即将推出的 Delphi 版本中启用该功能的功能怎么样? 也许它可能是一个编译器开关,促进所有 ** private **s to ** strict private **小号。 ... 或者它可能是
我可以通过将函数放入类的私有(private)扩展中来创建私有(private)函数,而不是通过不断调用 private func functionName(){} 来创建新的私有(private)函
部署专用端点并需要专用 IP 地址作为输出,但似乎无法正确获取值查询。下面的结果是“模板输出'主机名'无效:语言表达式属性|'privateIPAddress'具有无效的数组索引..(代码:Deplo
我是一名优秀的程序员,十分优秀!