12

说,我们有2个类:

public class A
{
    public int a;
}

public class B
{
    public int b;

    public static implicit operator B(A x)
    {
        return new B { b = x.a };
    }
}

那么为什么

A a = new A { a = 0 };
B b = a; //OK

List<A> listA = new List<A> { new A { a = 0 } };
List<B> listB = listA.Cast<B>().ToList(); //throws InvalidCastException

运算符也是explicit如此。

PS:手动(单独)铸造每个元素

List<B> listB = listA.Select<A, B>(s => s).ToList(); //OK
4

1 回答 1

10

的名称具有Enumerable.Cast误导性,因为它的目的是拆箱值。它适用于(IEnumerable适用IEnumerable<T>)以生成IEnumerable<T>. 如果您已经有一个IEnumerable<T> Enumerable.Cast很可能不是您想要使用的方法。

从技术上讲,它正在做这样的事情:

foreach(object obj in value)
    yield return (T)obj;

如果T不是装箱值,这将导致InvalidCastException.

您可以自己测试此行为:

int i = 0;
object o = i;
double d1 = (double)i; // Works.
double d2 = (double)o; // Throws InvalidCastException

您有两种可能的解决方案:

  1. 采用Select(x => (B)x)
  2. 创建一个Cast适用于IEnumerable<T>而不是IEnumerable.
于 2012-09-17T07:54:18.880 回答