天天看点

用DEF文件从DLL中导出C编程++类

用DEF从DLL导出一个参数,或用__deClspeC(dlleXPort)指令从DLL中导出一类,想必大家已经很熟悉了,也经常使用着。这里向大家介绍一种用DEF文档从DLL导出一个类的method。具体原理或为什么就不废话了,学会导出后,再慢慢回味吧。这里主要叙述操作步骤。

    1.打开VC6.0,新建一个"Win32 DynamiC-Link Library"工程,假设叫DefClass,在“Dll kind”选择界面中选择“A simple dll projeCt”

    2.新建一个文档,命名为DefClass.def,先暂时输入下面的内容,并加入工程。

    LIBRARY DefClass

    EXPORTS

    3.向工程中加入一个类CMath,并添加一个Addmethod,使之看起来如下:

 Class CMath  

      {

      publiC:

            int Add(int a,in b);

            CMath();

            virtual ~CMath();

      };

    它的呈现,你想如何由你决定,我做例子时,Add返回return a+b;

    4.打开工程的设置(settings)界面,选择Link,勾选Generate mapfile.

    5.Rebuild all工程。

    6.在VC中打开Debug或Release的*.map文档(如果你工程名这DefClass,那就是DelClass.map)。

    7.找到Math.obj,比如:

 0001:00000080       [email protected]@[email protected]           10001080 f   Math.obj

 0001:000000C0       [email protected]@[email protected]       100010C0 f i Math.obj

 0001:000000C0       [email protected]@[email protected]       100010C0 f i Math.obj

 0001:00000130       [email protected]@[email protected]           10001130 f   Math.obj

 0001:00000170       [email protected]@@[email protected]       10001170 f   Math.obj

    8.把1,4,5行的第2列拷贝到DefClass.Def文档中,使之成为下面的样子(序号自己指定)

 LIBRARY DefClass

 EXPORTS  

        [email protected]@[email protected]                         @1

       [email protected]@[email protected]               @2

      [email protected]@@[email protected]     @3    

    9.保存所有文档,再运行Rebuild All.

    如果一切正常,那你的DLL中的类已经以序号导出的了。这时再往CMath中加参数,如上从map文档中找到参数的标识符,并在def文档中加一项,分配一个序号给它。只要保持以前的导出序号不变,用新编译生成的DLL替换先前的DLL,以前的客户程式仍然可以正常运行。

    如何使用生成的DLL?

    你可以把"Math.h"和"DefClass.lib"拷贝到客户程式的工程目录下,把"DefClass.dll"拷贝到客户程式的输出(debug/release)目录下。 在客户程式中#inClude "Math.h",在客户程式的settings中加入对DefClass.lib引用。

    CMath Math;

    int nRet=Math.Add(2,3);

======================================

模块定义文件是一个有着.def文件扩展名的文本文件。它被用于导出一个DLL的函数,和__declspec(dllexport)很相似,但是.def文件并不是Microsoft定义的。一个.def文件中只有两个必需的部分:LIBRARY 和 EXPORTS。让我们先看一个基本的.def文件稍后我将解析之。

LIBRARY dll_tutorial

DESCRIPTION "our simple DLL"

EXPORTS

Add @1

Function @2

第一行,''LIBRARY''是一个必需的部分。它告诉链接器(linker)如何命名你的DLL。下面被标识为''DESCRIPTION''的部分并不是必需的,但是我喜欢把它放进去。该语句将字符串写入 .rdata 节[据 MSDN],它告诉人们谁可能使用这个DLL,这个DLL做什么或它为了什么(存在)。再下面的部分标识为''EXPORTS''是另一个必需的部分;这个部分使得该函数可以被其它应用程序访问到并且它创建一个导入库。当你生成这个项目时,不仅是一个.dll文件被创建,而且一个文件扩展名为.lib的导出库也被创建了。除了前面的部分以外,这里还有其它四个部分标识为:NAME, STACKSIZE, SECTIONS, 和 VERSION。我将不再在本文中涉及这些内容,但是如果你在Internet上搜索,我想你将找到一些东西(译注: MSDN2003上对模板定义文件各部分内容有详尽解释,请参阅)。另外,一个分号(;)开始一个注解

继续阅读