加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

具有多种类型的C#通用类型推断

发布时间:2020-12-16 00:20:14 所属栏目:百科 来源:网络整理
导读:我有以下通用方法将一种类型的输入对象序列化为超类型,如下所示: public string SerialiseAsTResult,TInput(TInput input) where TInput : TResult{ DataContractJsonSerializer ser = new DataContractJsonSerializer(typeof(TResult)); MemoryStream stre
我有以下通用方法将一种类型的输入对象序列化为超类型,如下所示:

public string SerialiseAs<TResult,TInput>(TInput input) where TInput : TResult
{
    DataContractJsonSerializer ser = new DataContractJsonSerializer(typeof(TResult));
    MemoryStream stream = new MemoryStream();
    ser.WriteObject(stream,input);
    stream.Position = 0;
    StreamReader reader = new StreamReader(stream);
    return reader.ReadToEnd();
}

我必须调用此方法指定两种泛型类型,如下所示:

MySubType x = new MySubType();
string json = SerialiseAs<MySuperType,MySubType>(x);

我的问题是,为什么不能在这种情况下推断TInput?是因为TResult实际上并没有用作返回类型吗?以下代码更清晰,但由于缺少输入类型而无法编译:

MySubType x = new MySubType();
string json = SerialiseAs<MySuperType>(x);

解决方法

My question is,why can’t TInput be inferred in this situation?

它可以 – 它是无法推断的TResult,并且无法指定“部分”推理.

您有时可以将类型参数分为通用类型的参数和通用方法的类型参数,因此您最终会得到:

// Explicitly state TResult,and infer TInput
Serializer<MySuperType>.Serialize(x);

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读