1

我想知道在我的项目中定义名称空间的更好方法。我们有 2 个不同的 winform 项目,并且我们在两个项目中都使用了某些代码文件和表单。所以项目1和2的结构如下:

//Project Pro1
//-------------------------------------
//Class C1 starts
#if pro1
using pro1
#endif
#if pro2
using pro2
#endif
namespace common_fun
{
Class C1
    Method M1
    {
        call to C2.M2
    }

}

//Class C2 starts
namespace pro1
{
Class C2
    Method M2

}

//Project Pro2
//----------------


#if pro1
using pro1
#endif
#if pro2
using pro2
#endif
namespace common_fun
{
Class C1
    Method M1
    {
        call to C2.M2
    }

}

namespace pro2
{
Class C2
    Method M2

}

所以在这里,类 C1(在命名空间 common_fun 下)是两个项目中使用的共享文件。但是,我们需要调用类 C2 的方法 M2,并且为了调用该方法,我们需要在顶部编写条件 using 语句。IE

#if pro1
using pro1
#elseif pro2
using pro2
#endif

所以我的问题是有没有更好的方法来包含公共文件的命名空间?将来可能会有 3-4 个项目使用相同的类/表单。

谢谢。

4

2 回答 2

1

我会创建一个包含您的 M2 方法的通用接口:

 interface ICommonFun
 {
      void M2();
 }

然后将该接口的实现传递给您的C1类:

 class C1
 {
      ICommonFun Instance;

      public void M1()
      { 
         Instance.M2();
      }

      public C1(ICommonFun fun)
      {
          Instance = fun;
      }
  }
于 2011-06-03T08:32:02.327 回答
1

我们在两个项目中都使用了某些代码文件和表单。

如果我理解正确,您可以在两个项目中引用这些代码文件,而不是将它们放入单独的程序集中。如果您尝试将“公共类”放在这样的库中(因为这是编写可重用代码时的最佳实践),您会注意到编译器/链接器不会让您这样做:相反,它会已经告诉你你在这里真正拥有的东西:C1 和 C2 的所有变体之间的循环依赖。这是您在创建要在不同项目之间共享的代码时真正应该避免的事情,因为它们使代码难以测试和维护(您已经注意到了,因为您的命名空间问题是可能发生的典型问题之一一种情况)。

sacklpicka 的解决方案(使用接口)是解决此问题的一种方法,使 C1 准备好放入它自己的库中。另一种是简单地M2在 的构造函数中作为委托传递C1,或者给出C1一个在调用 M1 时触发的事件,因此 C1 的用户可以将他们的方法注册M2为事件处理程序。

于 2011-06-03T08:35:20.480 回答