我有一个适用于泛型的方法:
public static IRestResponse<T> Get<T>(long id, string apiEndPoint) where T : new()
{
return Execute<T>(Method.GET, null, string.Concat(apiEndPoint, "/", id));
}
我使用此方法将视图模型作为泛型传递以获取解析结果:
var result = RestHelper.Get<AnyViewModel>(1, "Country"));
但是我遇到了一个案例,我有一个变量实体,我从中得到了视图模型:
var entity = "Country"; // This comes as a parameter
var viewModels = AppDomain.CurrentDomain.GetAssemblies().FirstOrDefault(x => x.FullName.Contains("Core.ViewModel"));
if (viewModels != null)
{
Type viewModel = viewModels.GetTypes().FirstOrDefault(x => x.Name.Contains(entity));
if (viewModel != null)
{
var result = RestHelper.Get<???>(1, entity);
}
}
所以我可以使用反射获取视图模型类型,但我不知道要传递给函数的<???>
泛型。
更新
我不知道这会对反射有多大影响,但我有Get
方法的更多重载:
public static IRestResponse Get(string apiEndPoint)
public static IRestResponse<T> Get<T>(string apiEndPoint) where T : new()
public static IRestResponse Get(long id, string apiEndPoint)
public static IRestResponse<T> Get<T>(long id, string apiEndPoint) where T : new()
答案 0 :(得分:2)
您必须使用反射来使用MakeGenericMethod
使用通用参数调用Get<T>
方法。
修改由于存在多次重载,请改用GetMethods
并将其缩小到您正在寻找的范围。 (我没有看到GetMethod
的重载,它允许您指定类型参数。)
MethodInfo method = typeof(RestHelper).GetMethods(BindingFlags.Static | BindingFlags.Public)
.Where(method => method.Name == "Get"
&& m.GetGenericArguments().Length == 1
&& m.GetParameters().Length == 2
// just to be certain, in case someone adds more overloads in the future ...
&& m.GetParameters()[0].ParameterType == typeof(int)
&& m.GetParameters()[1].ParameterType == typeof(string))
.FirstOrDefault();
if (method == null)
throw new InvalidOperationException("Couldn't find an overload of RestHelper.Get<T> with int, string parameters");
MethodInfo genericMethod = method.MakeGenericMethod(viewModel);
genericMethod.Invoke(null, new object[] { 1, entity });
修改强>
要使用&#34; List<viewModel>
&#34;,您可以使用Type.MakeGenericType
获取List<T>
:
var genericType = typeof(List<>).MakeGenericType(viewModel);
var genericMethod = method.MakeGenericMethod(genericType);