LIB和DLL中在.h文件中聲明函數的不同

LIB:  extern "C" int add(int x,int y);   //聲明爲C編譯、連接方式的外部函數 

在程序中如何引入lib.h:1)#pragma comment( lib, "..//debug//libTest.lib" )  //指定與靜態庫一起連接
                                           2)VC中 tools、options、directories、library files菜單或選項,填入庫文件路徑

引入lib.h後,就可以直接使用ADD函數。

 

DLL:extern "C" int __declspec(dllexport)add(int x, int y);  //聲明函數add爲DLL的導出函數

            DLL內的函數分爲兩種:(1)DLL導出函數,可供應用程序調用;

                                                        (2) DLL內部函數,只能在DLL程序使用,應用程序無法調用它們

引入Dll後,不能馬上調用Add數,要分爲幾個步驟來實現調用函數:

首先引入實例:

/* 文件名:lib.h */

#ifndef LIB_H
#define LIB_H
extern "C" int __declspec(dllexport)add(int x, int y);
#endif

/* 文件名:lib.cpp */

#include "lib.h"
int add(int x, int y)
{
 return x + y;
}

 

調用:

#include <stdio.h>
#include <windows.h>

typedef int(*lpAddFun)(int, int); //宏定義函數指針類型      -----------------(1)
int main(int argc, char *argv[])
{
 HINSTANCE hDll; //DLL句柄                                        -------(3)
 lpAddFun addFun; //函數指針                                        ------(2)
 hDll = LoadLibrary("..//Debug//dllTest.dll");                --------(3)
 if (hDll != NULL)
 {
  addFun = (lpAddFun)GetProcAddress(hDll, "add");  --------(4)
  if (addFun != NULL)
  {
   int result = addFun(2, 3);
   printf("%d", result);
  }
  FreeLibrary(hDll);                                                      ----------(5)
 }
 return 0;
}

(1).語句typedef int ( * lpAddFun)(int,int)定義了一個與add函數接受參數類型和返回值均相同的函數指針類型.如。net框架中的委託一樣。

 

(2).在main函數中定義了lpAddFun的實例addFun

(3).在函數main中定義了一個DLL HINSTANCE句柄實例hDll,通過Win32 Api函數LoadLibrary動態加載了DLLaddFun。經由函數指針addFun進行了對DLL中add函數的調用

(4).在函數main中通過Win32 Api函數GetProcAddress得到了所加載DLL模塊中函數add的地址並賦給了addFun。經由函數指針addFun進行了對DLL中add函數的調用

(5).應用工程使用完DLL後,在函數main中通過Win32 Api函數FreeLibrary釋放了已經加載的DLL模塊

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章