以下两种方法之间的语义区别是什么:
public static bool IsNullOrEmpty(this Array value)
{
return (value == null || value.Length == 0);
}
和
public static bool IsNullOrEmpty<T>(this T[] value)
{
return (value == null || value.Length == 0);
}
一个比另一个有优势吗?
最佳答案
第一个适用于任何数组,包括矩形数组和具有非零下限的数组。当数组的编译时类型只是 Array
时,它也可以工作,这可能偶尔会发生在相当弱类型的 API 中。
简而言之,第一个更通用,应该可以像第二个一样在任何地方工作。
(我假设你不想要任何“额外”的特性,比如在第二种形式中对 T
的额外限制......你只是想要一些东西来确定数组引用是空数组还是引用空数组。)
编辑:对于 IEnumerable
,您将使用:
public static bool IsNullOrEmpty(this IEnumerable value)
{
if (value == null)
{
return true;
}
var iterator = value.GetEnumerator();
try
{
return !iterator.MoveNext();
}
finally
{
// Non-generic IEnumerator doesn't extend IDisposable
IDisposable disposable = iterator as IDisposable;
if (disposable != null)
{
disposable.Dispose();
}
}
}
这样做的缺点当然是它很容易产生副作用 - 例如,您可以传入最终会与数据库对话的 LINQ 查询。
关于c# - 关于两种不同类扩展模式的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6790937/