考虑以下代码模式:
// 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/