关于从.net dll(C#)导出函数方法

时间:2011-04-19 21:33:21

标签: c# dll dllexport loadlibrary getprocaddress

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)的错误在哪里? 感谢。

1 个答案:

答案 0 :(得分:2)

在示例2和3中,您使用的是Marshal.GetDelegateForFunctionPointer,这是在处理非托管代码时使用的函数,以便将非托管函数指针转换为托管代理。 math程序集包含托管的.NET代码,因此您应该使用示例1中的Reflection。因此,除非您尝试在非托管的C,C ++,...库中重用功能,否则不要使用此函数。

你真的应该区分非托管(C,C ++,...)和托管代码(.NET)。