随笔 - 224  文章 - 41  trackbacks - 0
<2010年3月>
28123456
78910111213
14151617181920
21222324252627
28293031123
45678910

享受编程

常用链接

留言簿(11)

随笔分类(159)

随笔档案(224)

文章分类(2)

文章档案(4)

经典c++博客

搜索

  •  

最新评论

阅读排行榜

评论排行榜

原文地址:http://www.cppblog.com/amyvmiwei/archive/2008/01/02/40203.html

DLL中导出函数的声明有两种方式:一种为在函数声明中加上__declspec(dllexport),这里不再举例说明;另外一种方式是采用模块定义(.def) 文件声明,.def文件为链接器提供了有关被链接程序的导出、属性及其他方面的信息。


            首先创建 一个DLL程序,.cpp中
int __stdcall Add(int numa, int numb)
{
       return (numa + numb);
}

int __stdcall Sub(int numa, int numb)
{
        return (numa - numb);
}

然后创建一个.def的文件,在里面加上

;DllTestDef.lib : 导出DLL函数
;作者:----
LIBRARY defDll.dll
EXPORTS
Add @ 1
Sub @ 2

           最后创建一个测试程序:.cpp文件如下:
#include <iostream>
#include <windows.h>
using namespace std;

typedef int (__stdcall *Fun)(int , int);
HINSTANCE hInstance;
Fun fun;

int main()
{
 hInstance = LoadLibrary("defDll.dll");

 if (!hInstance)
  cout<<"Not Find this Dll"<<endl;
 fun = (Fun)GetProcAddress(hInstance, MAKEINTRESOURCE(1));
 cout<<fun(12,3)<<endl;;
 fun = (Fun)GetProcAddress(hInstance, "Sub");
 cout<<fun(7, 3)<<endl;
 FreeLibrary(hInstance);
}



说明:
.def文件的规则为:

  (1)LIBRARY语句说明.def文件相应的DLL;

  (2)EXPORTS语句后列出要导出函数的名称。可以在.def文件中的导出函数名后加@n,表示要导出函数的序号为n(在进行函数调用时,这个序号将发挥其作用);

  (3).def 文件中的注释由每个注释行开始处的分号 (;) 指定,且注释不能与语句共享一行。
posted on 2010-03-13 16:45 漂漂 阅读(413) 评论(0)  编辑 收藏 引用 所属分类: 深入vc++

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理