显试调用DLL------GetProcAddress的使用
来源:互联网 发布:java打包war步骤 编辑:程序博客网 时间:2024/06/07 00:52
1、关于typedef int(*lpAddFun)(int, int)
在非MFC DLL学习中出现了一个不太好懂的语句:
typedef int(*lpAddFun)(int, int); //宏定义函数指针类型
这句宏定义函数指针类型是什么意思呢? 资料来源:yuhaibin echo
我们知道typedef 是宏定义,一般的语法是这样:
typedef unsigned long ulong;
这个定义是用ulong作unsigned long 的别名
而在这里的意思是定义一种指针类型lpAddFun,它是一种指向函数int (int,int)的指针,也就是说lpAddFun表示的是这种类型的函数的地址。
换句话说,lpAddFun是typedef定义的一个名称,可以用来定义变量。
比如 lpAddFun p;
那p就是 int(*p)(int, int);
首先(*p)说明p是一个指针,(*p)();说明p指向函数,
(*p)(int, int)说明p指向的函数有两个int类型参数,
最后 int(*p)(int, int);说明p指向的函数返回值类型是int。
2、函数原型:FARPROC GetProcAddress(HMODULE hModule, // DLL模块句柄LPCSTR lpProcName // 函数名);hModule[in] 包含此函数的DLL模块的句柄。LoadLibrary、AfxLoadLibrary 或者GetModuleHandle函数可以返回此句柄。lpProcName[in] 包含函数名的以NULL结尾的字符串,或者指定函数的序数值。如果此参数是一个序数值,它必须在一个字的底字节,高字节必须为0。返回值:如果函数调用成功,返回值是DLL中的输出函数地址。如果函数调用失败,返回值是NULL。得到进一步的错误信息,调用函数GetLastError。GetProcAddress函数被用来检索在DLL中的输出函数地址。lpProcName指针指向的函数名,拼写和大小写必须和DLL源代码中的模块定义文件(.DEF)中输出段(EXPORTS)中指定的相同。Win32 API函数的输出名可能不同于你在代码中调用的这些函数名,这个不同被宏隐含在相关的SDK头文件中。如果想得到更多信息,请参考Win32函数原型(Win32 Function Prototypes)。lpProcName参数能够识别DLL中的函数,通过指定一个与函数相联系的序数值(在.DEF中的EXPORTS段)。GetProcAddress函数验证那个指定的序数值是否在输出的序数1和最高序数值之间(在.DEF中)。函数用这个序数值作为索引从函数表中读函数地址,假如.DEF 文件不连续地定义函数的序数值,如从1到N(N是输出的函数序数值),错误将会发生,GetProcAddress将会返回一个错误的、非空的地址,虽然指定的序数没有对应的函数。为了防止函数不存在,函数应该通过名字指定而不是序数值。要求:Windows NT/2000: 要求Windows NT 3.1 或以后版本。Windows 95/98: 要求Windows 95 或以后版本。头文件: 在Winbase.h中声明,include Windows.h。库文件: Use Kernel32.lib。动态链接库纵览(Dynamic-Link Libraries Overview), 动态链接库函数(Dynamic-Link Library Functions),FreeLibrary, GetModuleHandle, LoadLibrary示例代码:调用KERNEL32.DLL中的RegisterServiceProcess(仅在Windows98中适用)HMODULE hModule=GetModuleHandle("kernel32.dll");if (hModule) { typedef DWORD (CALLBACK *LPFNREGISTER)(DWORD,DWORD); LPFNREGISTER lpfnRegister; lpfnRegister=(LPFNREGISTER)GetProcAddress(hModule,"RegisterServiceProcess"); if (lpfnRegister) { (*lpfnRegister)(NULL,1L); } }
3、举个例子说明:和调用动态库时的那个typedef一致
#include <stdio.h>
#include <windows.h>
typedef int (*ADD)(int, int);
typedef int (*SUB)(int, int);
int main(int argc, char* argv[])
{
HMODULE hmodule11 = ::LoadLibrary("DynamicDLL.dll");
ADD Add= (ADD) GetProcAddress(hmodule11,"GetAdd");
SUB Sub= (SUB) GetProcAddress(hmodule11,"GetSub");
int x=10,y=5;
int nRes = Add(x,y);
int nRes2= Sub(x,y);
FreeLibrary(hmodule11);
printf("%d,%d\n",nRes,nRes2);
return 0;
}
〉其中ADD 和SUB 是两个函数指针类型。
0 0
- 显试调用DLL------GetProcAddress的使用
- dll的输出函数使用__stdcall调用约定后,客户端用GetProcAddress出现的问题!
- 动态调用DLL. LoadLibrary和GetProcAddress
- 用LoadLibrary和GetProcAddress函数调用dll的代码有问题
- C#【异常处理】调用dll。GetProcAddress 托管的 PInvoke 签名与非托管的目标签名不匹配?
- 使用函数GetProcAddress( )在纯C环境下调用动态链接库的一点心得...
- GetProcAddress() LoadLibrary() DLL
- 使用API函数GetProcAddress的注意事项
- 使用API函数GetProcAddress的注意事项
- 另类DLL加载方法(解析PE打造自己的GetProcAddress)
- 通过LoadLibrary() 与 GetProcAddress()获得Dll内的函数
- GetProcAddress 调用过程约定
- dll的调用、使用范例
- GetProcAddress 使用注意事项
- GetProcAddress 使用注意事项
- [Windows编程] 使用API函数GetProcAddress的注意事项
- GetProcAddress的用法
- GetProcAddress函数检索指定的动态链接库(DLL)中的输出库函数地址
- HBase1.0+ java-api 介绍
- Swift - 用装有控制器name的数组for循环批量创建控制器(string转UIViewController)
- 基于动态令牌的双因素身份认证——有力保障网上帐户和交易的安全
- setFocusable , setEnabled ,setClickable 区别
- 第15周 啊哈算法 排序算法
- 显试调用DLL------GetProcAddress的使用
- 腾讯云cos对象存储服务文件上传api就是一个大坑
- Android ToolBar修改返回按钮图标
- CodeForces 687C The Values You Can Make
- Maven学习笔记——常用插件配置详解
- 物理学基石 —— 麦克斯韦方程组
- 二,iOS应用架构谈 view层的组织和调用方案
- excel 数据读取(未在本地计算机上注册“Microsoft.Jet.OLEDB.4.0”提供程序)
- springmvc中方法之间的跳转。