0

我什至不确定如何描述我正在尝试做的事情(对不起,新手),但是因为我还没有弄清楚如何正确地做而复制代码在我的列表中并不重要。请问有什么帮助吗?

原始非泛型方法:

    public static string SerializetaUpdateCreateItemRcd(IVItemMasterType o)
    {
        eConnectType eConnect = new eConnectType();

        IVItemMasterType[] myMaster = { o };

        // Populate the eConnectType object with the schema object
        eConnect.IVItemMasterType = myMaster;

        return MemoryStreamSerializer(eConnect);
    }

我对通用的尝试,如此接近,在设置类型属性时迷失了(?):

    public static string Serialize<T>(T o) where T : eConnectType
    {
        eConnectType eConnect = new eConnectType();

        T[] myMaster = { o };

        // Populate the eConnectType object with the schema object
        eConnect.? = myMaster;

        return MemoryStreamSerializer(eConnect);
    }

更新:

抱歉,这一切可能只是一个架构问题,但大约有 166 种可能的组合,为每个组合编写一个步骤似乎很荒谬。不过,我可能不得不这样做......

对 eConnect 的 MS Doc 参考:http: //msdn.microsoft.com/en-us/library/ff623781.aspx

调用序列化的示例代码:

    IVItemMasterType o = new IVItemMasterType();

    o.eConnectProcessInfo = null;
    o.taCreateInternetAddresses_Items = null;
    o.taCreateItemVendors_Items = null;
    o.taCreateKitItemRcd_Items = null;
    o.taItemSite_Items = null;
    o.taIVCreateItemPriceListHeader = null;
    o.taIVCreateItemPriceListLine_Items = null;
    o.taRequesterTrxDisabler_Items = null;
    o.taUpdateCreateItemCurrencyRcd_Items = null;
    o.taUpdateCreateItemRcd = eConnectHelper.taUpdateCreateItemRcdFactory(eItem);

    // Serialize into string & add to list
    List<string> sList = new List<string>();             
    sList.Add(eConnectHelper.Serialize(o));

    // Submit list to eConnect
    eCreateEntity(sList);

序列化内存流代码:

    public static string MemoryStreamSerializer(eConnectType e)
    {
        XmlSerializer serializer = new XmlSerializer(e.GetType());

        using (var memoryStream = new MemoryStream())
        {
            serializer.Serialize(memoryStream, e);
            memoryStream.Position = 0;

            // Use memory streamed XML document to create a string representation of the object
            XmlDocument xmldoc = new XmlDocument();
            xmldoc.Load(memoryStream);
            memoryStream.Close();
            string sDocument = xmldoc.OuterXml;

            return sDocument;
        }
    }

更新 2:

非常感谢你们俩。在上面睡觉之后,我意识到我的架构中的错误。无论哪种方式,我都必须构建 eConnect 对象,并且我已经在前面的方法调用中构建了子类型对象,所以我已经回溯并将类型化的序列化代码移动到主调用方法中。

我确实尝试了反射,虽然它确实编译和运行,但由于某种原因,它除了 ObjectReference/NullReference 之外,尽管据我所知,所有对象都被填充。

这是我使用它的方式:

    public static string Serialize<T>(T o)
    {
        eConnectType e = new eConnectType();

        T[] myMaster = { o };

        // Populate the eConnectType object with the schema object
        typeof(eConnectType).GetProperty(typeof(T).Name).SetValue(e, myMaster, null);

        return MemoryStreamSerializer(e);
    }
4

3 回答 3

1

如果您确实需要访问与泛型类型同名的属性,则必须像这样使用反射

typeof(eConnectType).GetProperty(typeof(T).Name).SetValue(eConnect, myMaster, null);
于 2011-11-15T20:21:28.830 回答
1

经过仔细调试后,这个“getProperties”一直返回“null”引用,因为这个 eConnecType 类中的成员是“字段”而不是属性......这是修复......

public static string Serialize<T>(T o)
    {
        eConnectType e = new eConnectType();
        T[] myMaster = { o };

        // Populate the eConnectType object with the schema object 
        typeof(eConnectType).GetField(typeof(T).Name).SetValue(e, myMaster);
        return MemoryStreamSerializer(e);
    }
于 2012-02-22T19:04:15.727 回答
1

这里的问题是泛型类型参数无法控制属性名称。就泛型类型系统而言,eConnect具有称为属性的事实完全是巧合。IViewMasterType

你可以拥有eConnectType<T>一个属性public T[] SomePropertyName { get; set; }。换句话说,类型化的属性名称不能与其类型相关。然后你会这样做:

public static string Serialize<T>(T o)
{ 
    eConnectType<T> eConnect = new eConnectType<T>(); 

    T[] myMaster = { o }; 

    // Populate the eConnectType object with the schema object 
    eConnect.SomePropertyName = myMaster; 

    return MemoryStreamSerializer(eConnect); 
} 

但是如果没有看到更多的代码,很难判断这是否会有所帮助。

编辑

根据您的更新,我倾向于弗朗西斯使用反射的建议。反射速度较慢,但​​根据我的经验,它从未如此缓慢,以至于我实际上需要优化。

于 2011-11-15T19:47:35.713 回答