实现反射的过程中遇到的问题及解决方法(关于自定义类对象数组的深层拷贝)
在最近做的工程里,有一个需求是实现一个静态方法public static object CopyOjbect(object sourceObject),这个方法利用C#.net的反射机制,可以比较“通用地”返回几种自定义类对象的深层拷贝。在实现这个静态方法的过程中,曾经遇到了一点小问题,困扰了一整天的时间。现在把解决过程写出来,希望这点经验能给同样遇到这个问题的C#程序员一点小小的帮助。如果您有其他的解决方案,请不吝赐教。
这个方法的结构非常简单:首先利用sourceObject.GetType()方法,得到sourceObject的类型objectType,然后调用静态方法Activator.CreateInstance(objectType)得到该类型的一个新的实例newObject,这个返回实例用一个object引用来提领。接下来,使用objectType.GetProperties()得到该类型所有的公共属性(get-set属性)。对于其中的每一个属性,如果其类型是C#语言内置类型,如int, string, double等,就将sourceObject对象中这个属性的值直接赋给新对象newObject的相同属性。由于不知道这个object的实际类型,因此无法将这个ojbect引用显式cast成为实际类型,从而也就不能直接调用这个公共属性的set方法,而需要通过InvokerMember()方法来调用。InvokerMember的功能很强大,主要参数有需要调用的成员方法名,该成员方法所属的对象引用,以及一个包括目标成员方法参数列表的object[]。如果该属性不是一个C#语言内置类型,而是一个自定义类对象的引用,则递归copyObject()方法自身,得到这个自定义对象的一个新实例,并将该实例的引用赋值给这个属性。如果该属性是一个数组,则通过for循环来执行上述过程。
在处理类型为自定义类数组的属性时,问题出现了:
来看下面这两个类,首先是自定义类型MyClass:
public class MyClass{
//members;
}
和一个自定义类M