关于动态调用Dll的方法

简介:

前段时间做了一个项目,其中要求调用一个VC6开发的Dll文件,而该文件有多个不同的版本,所以要支持动态调用,并支持卸载。

在收集了一些这方面的资料后,编写了下面的类,该类可以方便的调用各种类型的dll,而且简单实用。

view plaincopy to clipboardprint?
using System;
using System.Collections.Generic;
using System.Text;
using System.Runtime.InteropServices;

namespace testdll
{
/// <summary>
///
/// </summary>
class InvokeDll
{
#region Win API
[DllImport("kernel32.dll")]
private extern static IntPtr LoadLibrary(string path);

[DllImport("kernel32.dll")]
private extern static IntPtr GetProcAddress(IntPtr lib, string funcName);

[DllImport("kernel32.dll")]
private extern static bool FreeLibrary(IntPtr lib);
#endregion

private IntPtr hLib;
public InvokeDll(String DLLPath)
{
hLib = LoadLibrary(DLLPath);
}

~InvokeDll()
{
FreeLibrary(hLib);
}

//将要执行的函数转换为委托
public Delegate Invoke (string APIName,Type t)
{
IntPtr api = GetProcAddress(hLib, APIName);
if (api == IntPtr.Zero)
return null;
else
return Marshal.GetDelegateForFunctionPointer(api, t);
}
}

}
using System;
using System.Collections.Generic;
using System.Text;
using System.Runtime.InteropServices;

namespace testdll
{
/// <summary>
///
/// </summary>
class InvokeDll
{
#region Win API
[DllImport("kernel32.dll")]
private extern static IntPtr LoadLibrary(string path);

[DllImport("kernel32.dll")]
private extern static IntPtr GetProcAddress(IntPtr lib, string funcName);

[DllImport("kernel32.dll")]
private extern static bool FreeLibrary(IntPtr lib);
#endregion

private IntPtr hLib;
public InvokeDll(String DLLPath)
{
hLib = LoadLibrary(DLLPath);
}

~InvokeDll()
{
FreeLibrary(hLib);
}

//将要执行的函数转换为委托
public Delegate Invoke (string APIName,Type t)
{
IntPtr api = GetProcAddress(hLib, APIName);
if (api == IntPtr.Zero)
return null;
else
return Marshal.GetDelegateForFunctionPointer(api, t);
}
}

}

使用时,先根据dll中的命令写出相关的代理

public delegate int MsgBox(int hwnd,string msg,string cpp,int ok);
public delegate int DeleteFile(string msg);

然后按下面的代码做就可以了。

view plaincopy to clipboardprint?
InvokeDll dll = new InvokeDll("user32.dll");
MsgBox mymsg = (MsgBox)dll.Invoke("MessageBoxA", typeof(MsgBox));
mymsg(this.Handle.ToInt32(), "txtmsg", "titleText", 64);


InvokeDll dll1 = new InvokeDll("kernel32.dll");
DeleteFile df= (DeleteFile)dll1.Invoke("DeleteFileA", typeof(DeleteFile));
df(deletedfilename);




本文转自94cool博客园博客,原文链接:http://www.cnblogs.com/94cool/archive/2009/08/31/1557050.html,如需转载请自行联系原作者

  

相关文章
|
C++
C/C++ DLL 简单实现
C/C++ DLL 简单实现
88 0
|
7月前
|
缓存
C++11实用技术(五)泛型编程加载dll接口函数
C++11实用技术(五)泛型编程加载dll接口函数
94 0
|
编译器 API C++
C++通过LoadLibrary的方式调用C封装的dll
C++通过LoadLibrary的方式调用C封装的dll
901 0
C++通过LoadLibrary的方式调用C封装的dll
|
C++
C++ 操作DLL的函数 Loadlibrary GetProcAddress FreeLibrary
C++ 操作DLL的函数 Loadlibrary GetProcAddress FreeLibrary
806 0
MFC创建动态链接库DLL并调用方法详解
实例一: 1、创建一个动态链接库工程,如login_dll。 2、在原工程头文件或者新建头文件如showdlg.h定义动态链接库的导出函数,代码如下: #include "stdafx.h"#define EXPORT __declspec(dllexport)extern "C"  EXPO...
3653 0
动态加载Dll时,通过Type生成类对象
原文:动态加载Dll时,通过Type生成类对象 转:http://www.cnblogs.com/zfanlong1314/p/4197383.html “反射”其实就是利用程序集的元数据信息。
944 0

热门文章

最新文章