考虑以下代码模式:

// Each foo keeps a reference to its manager
class Foo
{
    private FooManager m_manager;
}

// Manager keeps a list of all foos
class FooManager
{
    private List<Foo> m_foos;
}

问题:没有办法创建一个新的 Foo 并更新 FooManager 中的 m_foos 列表和新 Foo 实例中的 m_manager 引用,而不公开一些私有(private)信息(并且冒着有人将列表与实际 Foo 同步的风险)。

例如。可以在 Foo 中实现构造函数 Foo(FooManager manager)。它可以设置 m_manager 引用,但它无法访问 m_foos 列表。或者您可以在管理器中实现 CreateFoo() 方法。它可以访问 m_foos 列表,但无法在 Foo 中设置 m_manager。

在 C++ 中,显然可以将 FooManager 声明为 Foo 的 friend 来表达设计意图,但这在 C# 中是不可能的。我也知道我可以让 Foo 成为 FooManager 的内部类来获得访问权限,但这也不是一个解决方案(如果 Foo 可以属于多个管理器类呢?)

顺便提一句。我知道 .NET 中的“内部”访问,但它要求 Foo 和 FooManager 独立存在于单独的程序集中,这是 Not Acceptable 。

在不公开私有(private)内容的情况下,有什么解决方法吗?

最佳答案

如果我理解正确:

public abstract class FooBus
{
    protected static FooBus m_bus;
}

public sealed class Foo : FooBus
{
    private FooManager m_manager;

    public Foo(FooManager fm)
    {
        if (fm == null)
        {
            throw new ArgumentNullException("Use FooManager.CreateFoo()");
        }

        if (m_bus != fm)
        {
            throw new ArgumentException("Use FooManager.CreateFoo()");
        }

        m_manager = fm;
    }
}

public class FooManager : FooBus
{
    private List<Foo> m_foos = new List<Foo>();

    public Foo CreateFoo()
    {
        m_bus = this;
        Foo f = new Foo(this);
        m_foos.Add(f);
        m_bus = null;

        return f;
    }
}

关于c# - C# 中友元类用例的解决方法,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/5921612/

10-13 06:05