Circular References in my C# projects

前端 未结 4 1806
半阙折子戏
半阙折子戏 2021-02-13 11:56

I have the following situation:

  1. A project MyCompany.MyProject.Domain which contains my domain model, and partial classes (such as Contact

相关标签:
4条回答
  • 2021-02-13 12:31

    If you're sure about keeping the code in the utility DLL (Eric's answer seems smart to me), then you could create an interface in your utility project, pass that interface as a parameter to your ToSlug method and then have your domain object implement the interface.

    0 讨论(0)
  • 2021-02-13 12:33

    copy ToSlug method to Domain project and Delegate Utility's ToSlug call to this new method

    0 讨论(0)
  • 2021-02-13 12:39

    Your Utility project referencing your MyCompany.MyProject.Domain seems like a bit of a code smell. I'm assuming here that these are utilities that specifically work on domain objects--if that's the case, then why don't you include MyCompany.MyProject.Utilities within your Domain project (naturally, modifying the namespace accordingly)?

    In any case, the normal way to break these kinds of dependencies is to abstract what is required by one project into a set of interfaces, and encapsulate those in a separate assembly. Before doing that though, make sure that what you're doing conceptually is the right thing.

    In your particular situation though, consider introducing an interface, viz., INameHolder:

    public interface INameHolder
    {
        string FirstName { get; set; }
        string LastName { get; set; }
    }
    

    Then Contact implements INameHolder. INameHolder exists in another assembly, let's call it MyCompany.MyProject.Domain.Interfaces.

    Then your Utilities project references Interfaces (not Domain) and so does Domain, but Interfaces doesn't reference anything--the circular reference is broken.

    0 讨论(0)
  • 2021-02-13 12:40

    If you cannot share the domain (probably right) and it must consume the logic from a shared library then then you really have to introduce a another assembly.

    Or you could load the logic at runtime in the domain by reflection in the domain to access the dependent library. Its not hard just breaks compile time checking.

    0 讨论(0)
提交回复
热议问题