动态库的创建和调用

(一)动态链接库和静态链接库

静态链接库:lib中的函数不仅被连接,全部实现都被直接包含在最终生成的EXE文件中,只是实现是不可见的。

动态链接库:dll不必被包含在最终的EXE中,静态调用时仅把函数名或者变量名或者类名链接到EXE文件中,而这些东西的实体都只有在运行时才从动态库中导入到可执行文件中,动态调用的时候EXE文件执行时可以直接动态地引用和卸载DLL文件。

同时,静态链接库中不能再包含其他的动态链接库或静态库,而动态链接库中可以包含其他的动态或静态库。

(二)回顾一下VC++支持的DLL:

DLL的编制与具体的编程语言及编译器无关,动态链接库随处可见,VC++支持三种DLL:非MFC动态库、MFC规则DLL和MFC扩展DLL。DLL导出函数(或变量、类)可供应用程序调用;DLL内部函数只能在DLL程序内使用,应用程序无法调用它们。

(三)导出函数的声明方式:

一种在函数声明类型和函数名之间加上“_declspec(dllexport)”。

另外一种采用模块定义(.def)文件声明,需要在库工程中添加模块文件,格式如下:

LIBRARY 库工程名称

EXPORTS 导出函数名

(四)DLL的调用方式:

静态调用中,由编译系统完成对DLL的加载和应用程序结束时DLL的卸载。

动态调用中,由编程者用API函数加载和卸载DLL(DLL加载—DLL函数地址获取—DLL释放)方式。

接下来写个例子把上面提到的理论都实践一遍

一、 函数----创建动态链接库(MFC规则DLL)

1. New--projects--MFC AppWizard(dll)--Regular DLL using shared MFC DLL //取名为MFC_dll

2. def文件中添加:函数名(Add_new)

3. h文件中添加:外部函数声明//求和函数,函数名为Add_new

extern "C" __declspec(dllexport) int __stdcall Add_new(int a,int b);

4. cpp文件中添加: 外部函数实现

extern "C" __declspec(dllexport) int __stdcall Add_new(int a,int b)

{

return a+b;

}

5. build--set active configuration--win32 release--ok

6. 生成

7. 根目录下release文件夹中dll,lib与根目录下h文件即为所需

二、 函数----调用动态链接库(把MFC_dll.dll和MFC_dll.lib拷到工程所在目录)

//静态调用(.h可以写到.cpp文件中)

1. new--projects--win32 console application--an empty project

2. 添加h文件:(test.h)

#pragma comment(lib,"MFC_dll.lib") //告诉编译器DLL相对应的lib文件所在路径和文件名

extern "C" _declspec(dllimport) int _stdcall Add_new(int a,int b);//声明导入函数

3. 添加cpp文件:(main.cpp)

#include "test.h"

int main()

{

cout<<Add_new(10,3);

return 0;

}

//动态调用

#include <stdio.h>

#include <windows.h>

typedef int (* lpAddFun)(int ,int);//定义一个与Add_new函数接受参数类型和返回值均相同的函数指针类型

int main()

{

HINSTANCE hDll;//句柄

lpAddFun addFun;//函数指针

hDll=LoadLibrary("dllTest.dll");//动态加载DLL模块句柄

if(hDll)

{

addFun=(lpAddFun) GetProcAddress(hDll,"Add_new");//得到所加载DLL模块中函数的地址

if(addFun)

{

int result=addFun(2,3);

printf("%d",result); } FreeLibrary(hDll);//释放已经加载的DLL模块

}

return 0;

}

三、 变量----创建动态链接库(非MFC DLL)

1. new---projects---win32 dynamic-link library----an empty project(Sample)

2. 添加sample.h

#ifndef SAMPLE_H

#define SAMPLE_H

extern int dllGlobalVar;

#endif

3. 添加 sample.cpp

#include "sample.h"

#include <windows.h>

int dllGlobalVar;

bool APIENTRY DllMain(HANDLE hModule,DWORD ul_reason_for_call,LPVOID lpReserved)

//windows在加载DLL时,需要一个入口函数,就如同控制台或DOS程序需要main函数、win32程序需要winmain函数一样。所以引入一个不做任何操作的缺省DllMain的函数版本。是DLL的内部函数。

有一点要注意,如果看到此类宏定义
#ifdef KSCANBAR_EXPORTS
#define KSCANBAR_API __declspec(dllexport)
#else
#define KSCANBAR_API __declspec(dllimport)
#endif
是因为

这样定义一般出现在含有多个项目的解决方案中,这样可以使从 DLL 导出更简单的宏的标准方法。此 DLL 中的所有文件都是用命令行上定义的 KSCANBAR_EXPORTS符号编译的。在使用此 DLL 的任何其他项目上不应定义此符号。这样,源文件中包含此文件的任何其他项目都会将KSCANBAR_API 函数视为是从 DLL 导入的,而此 DLL 则将用此宏定义的符号视为是被导出的。

转自http://blog.csdn.net/crich_moon/article/details/6039939

时间: 2024-08-03 01:03:43

动态库的创建和调用的相关文章

VC++6.0 动态库的创建与调用(非MFC的dll)

非MFC动态库的创建... 一个lib.cpp,一个lib.h /*lib.h*/ #ifndef LIB_H #define LIB_H //声明add为dll的导出函数. extern "C" int _declspec(dllexport)add(int x,int y); #endif 也可以加上def文件 ; lib.def : 导出DLL函数 LIBRARY DllTestDef EXPORTS add @ 1 非MFc动态库的调用 1.静态调用 //静态的调用dll动态库

linux下动态库的编写和调用

linux下动态库的编写和调用 linux下编写和调用一个简单的动态库大概分为以下几个步骤: - 创建动态库程序文件 add.c int add(int a,int b) { return a+b; } 创建引用头文件 head.c #ifndef _HEAD_ #define _HEAD_ int add(int a,int b); #endif 生成目标文件 生成要加编译器选项 -fpic gcc -fpic -c add.c 然后生成动态库 注意使用链接器选项 -shared gcc -s

C/C++ (函数、变量和类)动态库的创建、导出和使用(图文+示例代码)

 一 Windows库 1引入库的原因: a.项目的复杂程度大 b.提高代码的利益利用率 2库的分类 2.1静态库: *.lib,不能被加载的程序,可以理解为目标程序的归档. 2.2动态库:*.dll,可以被应用程序加载的程序. 二 动态库 1动态库优点 1.1可以提供模块化的方式,方便协调开发(对于大项目,每个人写的东西编译为动态库,直接链接即可) 1.2对源代码保护 1.3减小可执行文件大小 1.4提高代码重用率 2动态库的基本使用方法 2.1动态库的创建 2.2加载动态库 2.3获取并

2017-2018-2 20155228 《信息安全系统设计原理》 动态库的生成和调用

2017-2018-2 20155228 <信息安全系统设计原理> 动态库的生成和调用 不得不说一下关于环境的问题 只要我打一个响指,一半的安装在win7上的VC6.0都会因为兼容性问题直接崩掉 懒得研究怎么解决兼容性的问题了,直接开一个winXP虚拟机完美运行vc6.0,省时省心,岂不美哉 研究大佬的博客的时候 Windows下静态库与动态库的创建与使用 尝试使用.def文件生成动态库并使用隐式链接到工程时,发现这个方法仅适用于动态库所在的工程和调用动态库的工程同时处于一个工作空间 如图所示

C++(VS2012)DLL动态库的生成和调用

DLL动态链接库的生成: 首先打开VS2012,新建——项目——Win32控制台应用程序(项目名称:ConsoleApplication1)——空项目 新建一个源文件source.cpp 先用控制台exe配置类型自己定义函数,并通过主函数调试 然后可以通过项目——属性——配置属性——常规——项目默认值——配置类型下 选择动态库(.dll)选项 然后点击Build,会在工程的Debug目录下生成一个DLL文件(ConsoleApplication1.dll) extern "C" _de

QT共享库的创建与调用(初级)

背景: 最近在做的一个项目其中一部分既是实现PC与下位机的USB通信.windows平台下已经完成,现需移植到linux平台下. 在linux系统中,通过一段时间的工作,设备已被配置成hid类(后续再详述),并以hidraw类设备节点存在于系统中"/dev/"下.上位机则成功在console中通过调用HIDAPI库来写入.读取hidraw设备节点信息(后续再详述),而进一步的图形界面则需由QT来完成. hidraw设备介绍: https://www.kernel.org/doc/Doc

动态库的创建与使用(1)

我们都知道库的作用有两个:1.文件共享的作用 2.知识产权的保护,虽然说库的功能都是一样的,但是动态库的制作比静态库稍微麻烦一些.到底哪些地方比较麻烦呢? 1)首先创建一个Win32动态链接库的工程. 2)在头文件中给出函数的声明,在源文件中给出函数的实现. 3)在打开工程的debug文件后我们发现有一个.dll文件,这就是传说中的静态库文件.但是这个文件暂时还不能使用.我们打开这个文件发现这里面都是二进制代码我们不能看懂.但是有专门针对二进制文件的工具.打开工具栏,点击depends点开后将这

linux下动态库的创建与使用

动态库创建 1.编译动态库 Vim add.cpp int add(int a, int b) { return a + b; } Vim add.h Int add(int a, int b); g++ add.cpp -o libadd.so -fPIC -shared 2.链接动态库 #include "add.h" #include <iostream> int main() { int ret = add(2, 3); std::cout << ret

静态链接库与动态链接库的区别及动态库的创建(转)

一.引言通常情况下,对函数库的链接是放在编译时期(compile time)完成的.所有相关的对象文件(object file)与牵涉到的函数库(library)被链接合成一个可执行文件(executable file).程序在运行时,与函数库再无瓜葛,因为所有需要的函数已拷贝到自己门下.所以这些函数库被成为静态库(static libaray),通常文件名为"libxxx.a"的形式.其实,我们也可以把对一些库函数的链接载入推迟到程序运行的时期(runtime).这就是如雷贯耳的动态