首页 > 解决方案 > c#基类方法返回派生类

问题描述

所以我有一个应用调用了一个LOAD的 WebServices,所有这些都有一个响应类,每个响应类都是从 ResponseBase 派生的

public abstract record ResponseBase<T>
{
    public HashSet<string> ErrorMessages { get; set; }

    public bool Success { get; set; }

    public virtual string Message => Success ? "Success" : string.Join(", ", ErrorMessages);

    public IEnumerable<T> Results { get; set; }
    public T Result { get; set; }
}

现在我目前创建这样的新响应:

var results = SomeService.GetSomeResults();
return new SomeDerivedResponse() { Success = true; Results = results }

为了简洁、清晰、一般的代码清洁度,我想做更像是:

var results = SomeService.GetSomeResults();
return new SomeDerivedResponse().WithSuccess(results);

WithSuccess() 只会相应地分配 Success = true 和 Results = results

无需在每个派生响应类(有数百个)中放置相同的 WithSuccess() 方法。我几乎用基类中的通用 WithSuccess() 方法到达那里,但它返回基类,而不是派生类,这意味着我有这个双重考虑:

return new SomeDerivedResponse().WithSuccess<SomeDerivedResponse>(results);

任何方式我都可以告诉编译器推断是什么,或者有更好的方法来做到这一点?

标签: c#genericsinheritance

解决方案


使用像这样的通用扩展方法应该可以工作:

public static class Ext
{
    public static T WitSuccess<T, R>(this T t, IEnumerable<R> r) where T : ResponseBase<R>
    {
        // your logic here
        return t;
    }

    public static T WitSuccess<T, R>(this T t, R r) where T : ResponseBase<R>
    {
         // your logic here
        return t;
    }
}

和用法:

public record SomeDerivedResponse : ResponseBase<int>{}
public record SomeDerivedResponse1<T> : ResponseBase<T>{}

new SomeDerivedResponse().WitSuccess(new []{1});
new SomeDerivedResponse1<int>().WitSuccess(1);

推荐阅读