math.dll
namespace math
{
public class MyClass {
public static int Add(int x, int y)
{
return x+y;
}
}
在我的exe项目中,我想使用Add()函数,
示例1 - 这是有效的
public void Example_1()
{
SampleAssembly = Assembly.Load("math");
Type type = SampleAssembly.GetType("math.MyClass");
MethodInfo methodInfo = type.GetMethod("Add");
if(methodInfo != null)
{
object result = null;
ParameterInfo[] parameters = methodInfo.GetParameters();
object classInstance = Activator.CreateInstance(type, null);
object[] parametersArray = new object[] { 3, 5 };
result = methodInfo.Invoke(classInstance, parametersArray);
MessageBox.Show(result.ToString());
}
}
示例2 - 这不起作用
public delegate int Add(int x,int y);
public void Example_2()
{
SampleAssembly = Assembly.Load("math");
Type type = SampleAssembly.GetType("math.MyClass");
MethodInfo methodInfo = type.GetMethod("Add");
if(methodInfo != null)
{
Add add = (Add)Marshal.GetDelegateForFunctionPointer
(methodInfo.MethodHandle.GetFunctionPointer(),typeof(Add));
MessageBox.Show(add(3,2).ToString());
}
}
示例3 - 这不起作用
public void Example_3() {
IntPtr hdl = LoadLibrary("math.dll");
IntPtr addr = GetProcAddress(hdl,"MyClass");
IntPtr myfunction = GetProcAddress(addr,"Add");
Add add= (Add)Marshal.GetDelegateForFunctionPointer(hdl,typeof(Add));
MessageBox.Show(add(2,3).ToString());
}
你能告诉我不工作的例子(2,3)的错误在哪里? 感谢。
答案 0 :(得分:2)
在示例2和3中,您使用的是Marshal.GetDelegateForFunctionPointer
,这是在处理非托管代码时使用的函数,以便将非托管函数指针转换为托管代理。 math
程序集包含托管的.NET代码,因此您应该使用示例1中的Reflection。因此,除非您尝试在非托管的C,C ++,...库中重用功能,否则不要使用此函数。
你真的应该区分非托管(C,C ++,...)和托管代码(.NET)。