2

我在使用如下代码克隆动态对象时遇到问题:

    public void Execute(IPrepareData entity)
    {
        try
        {                
            dynamic data = entity.Primary as dynamic;
            data.PreviousInfo = deepClone(data.Info);
        }
        catch (Exception ex)
        {
            data.Errors.Add(ex.Message);
        }
    }

    private static T deepClone<T>(T obj)
    {
        if (typeof(T).IsClass || typeof(T).IsArray)
        {
            if (ReferenceEquals(obj, null))
            {
                return default(T);
            }
        }
        using (var memoryStream = new MemoryStream())
        {
            BinaryFormatter fieldFormatter = new BinaryFormatter();
            fieldFormatter.Serialize(memoryStream, obj);
            memoryStream.Position = 0;
            return (T)fieldFormatter.Deserialize(memoryStream);
        }
    }

    dynamic data;

我事先不知道实体的结构(只知道它会包含Info,我不知道info的结构)并且它不会被标记为可序列化。我需要将此信息复制到实体的先前信息部分。

此代码的执行结果是 fieldFormatter.Serialize 行上的“对象引用未设置为对象的实例”。

如何检查它是否是对象的实例?

可能有(很可能会有)循环引用,所以我没有尝试反思,因为我不确定如何处理。速度也不是问题。

4

3 回答 3

6

关于什么

var clone = JsonConvert.DeserializeObject<dynamic>(JsonConvert.SerializeObject(obj));
于 2017-06-22T14:36:42.013 回答
3

如果您不知道数据将被标记为可序列化,那么您不能依赖使用BinaryFormatter.

如果对象可能有循环引用,那么很多其他的序列化器都是不可能的。

如果我们假设它是(而不仅仅是)的一般情况那么就无法获取有关成员的信息,因为可以在查询时发明它们。dynamicExpandoObject

基本上,这种情况*没有好的答案。没有什么神奇的方法可以深度克隆“一个东西”。

于 2012-09-26T12:58:32.333 回答
0

我一直在使用JSON.net来序列化用户定义的类型,并且运行良好。

有一些标志可以忽略空属性,或者默认情况下会另存为

{propname: 'undefined'}

我知道您提到速度不是问题,但是序列化程序非常快。

这是nuget 包

于 2013-05-10T02:02:45.627 回答