Item 17: Avoid Multiple Constraint Ambiguity避免多重约束中的含糊
当使用约束的时候,可以选择对任何一个类型参数使用多重约束。事实上,你可以将单独的类约束与多重接口约束联合使用。当你开始混合并匹配多重约束的时候,可能引入含糊不清的约束。
如:
public interface I
{
void Foo1();
void Foo3();
}
public class C
{
public void Foo1() {}
}
public class TestClass<T> where T : C, I { }
这里接口I和类C中的Foo1产生了混淆。
Item 18: Provide Parameterless Constructors提供无参构造器
无论何时,当你引入自定义类型的时候,都需要考虑当他们被用作类型参数的时候会产生什么样的行为。显然,你选择实现的接口会在该类型如何被约束方面起关键性的作用。至少,准备用为类型参数的每个类型都应该包含对参数构造的支持。通过支持这个约束,使得你的类型可以被任何包含构造约束的泛型类型所支持。
通过支持无参数的构造器来增加你的接口的价值的实例足够多,不过是对于泛型还是非泛型解决方案。如果你曾经和工厂模式的任何一种变形打过交道,你可能已经提供过无参构造器。有了泛型,该条款可以增加价值的场景的列表只会变得更长。
例如:
public IEnumerable<T> GetDataObjects() where T : new() {}