run(strPath){
try{
var
objShell=new
ActiveXObject("wscript.shell")
objShell.Run(strPath)
objShell=null
}
catch
(e){alert('找不到文件"'+strPath+'"(或它的组件之一)。请确定路径和文件名是否正确,而且所需的库文件均可用。')
}
}
调用时用:run(文件路径)
如果你有a.dll和a.lib,两个文件都有的话可以用静态加载的方式:message函数的声明你应该知道吧,把它的声明和下面的语句写到一个头文件中
#pragma comment(lib, "a.lib")
然后你的对话框.cpp中包含这个头文件就可以使用message函数了。
如果dll没有对应的.lib文件,那么就只能使用动态加载的方式了。
动态调用动态库步骤:
1、创建一个函数指针,其指针数据类型要与调用的DLL引出函数相吻合。
2、通过Win32 API函数LoadLibrary()显式的调用DLL,此函数返回DLL的实例句柄。
3、通过Win32 API函数GetProcAddress()获取要调用的DLL的函数地址,把结果赋给自定义函数的指针类型。
4、使用函数指针来调用DLL函数。
5、最后调用完成后,通过Win32 API函数FreeLibrary()释放DLL函数。
例如:
假设函数的声明为:void message(int a)
//函数指针声明
typedef void (WINAPI MESSAGE)(int a)
MESSAGE *pMessage = 0
//加载a.dll
HINSTANCE hDLLDrv = LoadLibrary("a.dll")
//获取message函数的指针
if(hDLLDrv)
{
pMessage = (MESSAGE *)GetProcAddress(hDLLDrv, "message")
}
然后就可以这样调用函数了:
pMessage(1)
1。可以把dll拷贝到 程序同一目录,这样程序才能加载dll2.可以把dll的路径加载到系统的环境变量PATH中,这样程序也能找到dll
建议你看看dll加载顺序和dll相关知识。
希望能够帮到您!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)