如果一个人调用了一个.Max()扩展方法IEnumerable<T>,并且其中的对象没有实现IComparable,那么就得到了System.ArgumentException: At least one object must implement IComparable.
为什么不Max和类似的方法约束T实现IComparable,以便可以在编译时而不是在运行时捕获此问题?
比较很有趣.首先,您可以选择IComparable<T>或IComparable- 您会选择哪个?目前(via Comparer<T>.Default)它支持两者,但没有"this or that"通用约束.
然后你得到了问题Nullable<T>; 这已经"解除"了比较,所以它是否具有可比性取决于T; 但同样,Comparer<T>.Default为我们处理这个问题(Nullable<T>既不实现IComparable也不实现IComparable<T>).
加; 它节省了通用约束传播; 一旦你在库代码中有这样的约束,它就会迅速感染所有上游调用代码,使其成为一个艰难的过程.
我想因为它更灵活.例如,您可能有一个IEnumerable<object>碰巧包含字符串的情况,在这种情况下Max()可以非常安全地调用它,尽管该类型Object没有实现IComparable.