このクラスを考える:
public class Foo
{
public void M1(int i){}
public void M2(int i, string s){}
public void M3(int i, string s){}
public int M4(int i, string s){ return 0; }
}
反射とLINQのビットを使用することができる。
Type t = typeof (Foo);
var theMethods = t.GetMethods().Where(mi =>
{
var p = mi.GetParameters();
if (p.Length != 2)
return false;
if (p[0].ParameterType != typeof(int)
|| p[1].ParameterType != typeof(string))
return false;
return mi.ReturnType == typeof (void);
});
または(この場合、実際に進歩して)他の構文
var theMethods = from mi in t.GetMethods()
let p = mi.GetParameters()
where p.Length == 2
&& p[0].ParameterType == typeof (int)
&& p[1].ParameterType == typeof (string)
&& mi.ReturnType == typeof (void)
select mi;
試験:
foreach (var methodInfo in theMethods)
{
Console.WriteLine(methodInfo.Name);
}
出力:
public static class Extensions
{
public static IEnumerable<MethodInfo> GetMethodsBySig(this Type type, Type returnType, params Type[] parameterTypes)
{
return type.GetMethods().Where((m) =>
{
if (m.ReturnType != returnType) return false;
var parameters = m.GetParameters();
if ((parameterTypes == null || parameterTypes.Length == 0))
return parameters.Length == 0;
if (parameters.Length != parameterTypes.Length)
return false;
for (int i = 0; i < parameterTypes.Length; i++)
{
if (parameters[i].ParameterType != parameterTypes[i])
return false;
}
return true;
});
}
}
そして、このようにそれを使用します:
var methods = this.GetType().GetMethodsBySig(typeof(void), typeof(int), typeof(string));
小胞体のようにそれを使用して...私の答えは、わずかに異なる構文LINQ、でした。 – Jamiec
ok - more linqified ... lambaとして書くのではなく、シーケンスを等価なものにする...コメントを変更します。 –