gpt4 book ai didi

c# - IoC 预期接口(interface)的命名约定

转载 作者:太空宇宙 更新时间:2023-11-03 12:17:00 25 4
gpt4 key购买 nike

当您使用 IoC 框架时,您最终会专门为 IoC 创建接口(interface)。我很想为这些使用命名约定。

例如,图片上没有IoC,你可能有如下的业务领域驱动结构:

interface IBodyPart
{
string ScientificName { get; set; }
string StreetName { get; set; }
}

class Head : IBodyPart
{
public string ScientificName { get; set; }
public string StreetName { get; set; }
}

class BodyPartPoker
{
bool isSituationAcademic;
BodyPartPoker(bool isSituationAcademic)
{
this.isSituationAcademic = isSituationAcademic;
}

void Poke(IBodyPart bodyPart)
{
if (this.isSituationAcademic)
Debug.Print($"Proceeding to poke {bodyPart.ScientificName}");
else
Debug.Print($"Poking that {bodyPart.StreetName} LOL");
}
}

现在假设您想使用 IoC 注入(inject) BodyPartPoker 实例。您还想使用某种单元测试模拟框架来测试该逻辑。

在这种情况下,即使您没有针对它的业务领域案例,您也会引入 IBodyPartPoker 接口(interface):

interface IBodyPartPoker
{
bool IsSituationAcademic { get; set; }
void Poke(IBodyPart bodyPart);
}

class BodyPartPoker : IBodyPartPoker
{

我的问题是:为像 IBodyPartPoker 这样的接口(interface)制定一个命名约定是否有意义,以便我们明确确定它的目的是与业务领域无关?

说....

interface IIocBodyPartPoker

最佳答案

在 C# 中,约定通常是利用语言的惯用命名约定,并使用前面的 I 命名接口(interface),如 IBodyPartPoker。这使得 BodyPartPoker 可以自由作为类的名称。

在 Java 中,惯例是命名一个没有匈牙利符号的接口(interface),因此该接口(interface)通常被命名为 BodyPartPoker,这通常会导致人们将他们的单个类命名为 BodyPartPokerImp.

您应该认为这是一种代码味道,正是因为接口(interface)存在的唯一原因似乎是启用单元测试。你可以说它违反了 Reused Abstractions Principle .

给接口(interface)起另一个名字,比如 IIocBodyPartPoker,并不能解决根本问题。

如果一个接口(interface)专门用于支持单元测试,您很可能会发现测试与实现细节过于耦合,并且每次您尝试重构生产代码时,测试都会中断。同样,命名约定不会解决此类问题。

关于c# - IoC 预期接口(interface)的命名约定,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49304078/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com