VC|创建、动态显式、静态隐式调用或链接动态链接库DLL
cac55 2024-12-16 11:16 40 浏览 0 评论
编写应用程序通常都不是从0开始的,或多或少都会用到一些库,不管是函数库还是类库。
动态链接库DLL(dynamic linked library)通常都不能直接运行,也不能接收消息。它们是一些独立的文件,其中包含能被可执行程序或其它DLL调用来完成某项工作的函数。只有在其它模块调用动态链接库中的函数时,它才发挥作用。
动态链接可以在编译时加载,也可以在运行时加载,加载时DLL被映射到进程的地址空间中。
1 创建动态链接库dll
1.1 建立一个简单的win32 dll工程mydll
1.2 添加mydll.h文件作为使用dll的接口(隐式链接时使用),并添加导出的函数fnTest()的声明:
int fnTest(void);
1.3 在mydll.cpp中添加需要导出的函数fnTest()
// mydll.cpp : Defines the entry point for the DLL application.
//
#include "stdafx.h"
BOOL APIENTRY DllMain( HANDLE hModule,
DWORD ul_reason_for_call,
LPVOID lpReserved
)
{
return TRUE;
}
int fnTest(void)
{
return 100;
}
1.4 在工程中添加如下内容的mydll.def文件
; mydll.def : Declares the module parameters for the DLL.
LIBRARY "mydll"
DESCRIPTION 'mydll Windows Dynamic Link Library'
EXPORTS
fnTest
从DLL中导出函数,可以使用模块定义文件(DEF),由一个或多个用于描述DLL属性的语句组成的文本文件,常用的语句如下,
LIBRARY语句:设置DLL的内部名。
DESCRIPTION语句:设置DLL的描述。
EXPORTS语句:设置被导出函数的名称。
SECTIONS语句:设置段属性。
以上代码运行会生成一个mydll.dll、mydll.lib文件。
?.h头文件,包含dll中说明输出的类或符号原型或数据结构的.h文件。应用程序静态隐式调用dll时,需要将该文件包含入应用程序的源文件中。
?.LIB文件,是dll在编译、链接成功之后生成的文件,作用是当其他应用程序静态隐式调用dll时,需要将该文件引入应用程序。
? dll文件,包含函数定义的文件,开发成功后的应用程序在发布时,只需要有.exe文件和.dll文件,并不需要.lib文件和.h头文件。
2 动态显式调用或链接dll
动态调用方式是由编程者用 API 函数加载和卸载 DLL 来达到调用 DLL 的目的,使用上较复杂,但能更加有效地使用内存,是编制大型应用程序时的重要方式。
显式的调用是指在应用程序中用 LoadLibrary 或 MFC 提供的 AfxLoadLibrary 显式的将自己所做的动态连接库调进来,动态连接库的文件名即是上面两个函数的参数,再用 GetProcAddress() 获取想要引入的函数指针。自此,你就可以象使用如同本应用程序自定义的函数一样来调用此引入函数了。在应用程序退出之前,应该用 FreeLibrary 或 MFC 提供的 AfxFreeLibrary 释放动态连接库。
因为DLL 有占用内存小、好编辑等的特点,有很多电脑病毒都是DLL格式文件。
显式链接是指应用程序在运行时通过函数调用来显示加载DLL,并通过函数指针来调用 DLL的导出函数。
显式链接首先调用SDK的LoadLibrary函数加载DLL,然后调用GetProcAddress函数获取导出函数的地址,最后使用完毕时调用FreeLibrary函数释放DLL。一些函数定义如下:
HMODOLE LoadLibrary(LPCTSTR IpFileName);
FARPROC GetProcAddress (HMODULE hModule, LPCSTR IpProcName);
BOOL FreeLibrary(HMODULE hModule);
2.1 创建一个对话框工程Usedll;
2.2 将mydll.dll复制到当前路径;
2.3 添加按钮和消息响应函数OnExUsedll():
void CUsedllDlg::OnExUsedll()
{
//加载DLL
HINSTANCE hModule = LoadLibrary(_T("mydll.dll")); // dll要复制到相同路径下
if (hModule == NULL)
{
AfxMessageBox(_T("mydll.dll加载失败\n"));
return;
}
typedef int (_cdecl *FUNTEST)(void);
FUNTEST pfnTest;
//获得导出函数的地址
pfnTest = (FUNTEST)GetProcAddress(hModule, "fnTest");
//调用导出函数
if (pfnTest != NULL)
{
int nValue = (*pfnTest)();
CString strMessage = _T("");
strMessage.Format(_T("%d"), nValue);
AfxMessageBox(strMessage);
}
else
{
int n = GetLastError();
TRACE(_T("LastError:%d\n"), n);
}
//释放DLL
FreeLibrary(hModule);
}
3 静态隐式调用或链接dll
程序员在建立一个 DLL 文件时,链接程序会自动生成一个与之对应的 LIB 导入文件。该文件包含了每一个 DLL 导出函数的符号名和可选的标识号,但是并不含有实际的代码。LIB 文件作为 DLL 的替代文件被编译到应用程序项目中。
隐式调用需要把产生动态连接库时产生的 .LIB 文件加入到应用程序的工程中,想使用 DLL 中的函数时,只须说明一下。隐式调用不需要调用 LoadLibrary() 和 FreeLibrary()。
当程序员通过静态链接方式编译生成应用程序时,应用程序中的调用函数与 LIB 文件中导出符号相匹配,这些符号或标识号进入到生成的 EXE 文件中。LIB 文件中也包含了对应的 DL L文件名(但不是完全的路径名),链接程序将其存储在 EXE 文件内部。
隐式链接需要应用程序在编译时链接包含导出函数的头文件、.dll、.lib文件,在运行时加载DLL,直接调用DLL的导出函数。
3.1 将mydll.h、mydll.lib复制到上面工程的当前路径(也需要mydll.dll);
3.2 在UsedllDlg.cpp中添加以下内容:
// UsedllDlg.cpp : implementation file
//DLL导出函数的头文件
#include "mydll.h"
//DLL的导入库lib文件,编译是通过静态链接库(lib)去找接口的
#pragma comment(lib, "mydll.lib")
3.3 添加按钮和消息响应函数OnImUsedll()
void CUsedllDlg::OnImUsedll()
{
// 直接调用DLL的导出函数
int nValue = fnTest();
CString strMessage = _T("");
strMessage.Format(_T("%d"), nValue);
AfxMessageBox(strMessage);
}
lib是编译时需要的,dll是运行时需要的。如果要完成源代码的编译,有lib就够了。如果也是动态连接的程序运行起来,有dll就够了。
如果有dll文件,那么对应的lib文件一般是一些索引信息,具体的实现在dll文件中。
如果只有lib文件,那么这个lib文件是静态编译出来的,索引和实现都在其中。
静态编译的lib文件有好处,给用户安装时就不需要再挂动态库了。但也有缺点,就是导致应用程序比较大,而且失去了动态库的灵活性,在版本升级时,同时要发布新的应用程序才行。
-End-
相关推荐
- 远程桌面管理服务器的软件工具:Splashtop
-
通过远程控制和维护服务器,IT运维无需亲自在设备附近就可以轻松完成工作,极大地提高了效率。在本文中,我们将深入了解远程桌面管理服务器的主要优点,以及实现此任务所需的软件工具和操作方法。首先,远程桌面管...
- 最担心的事还是发生了 19岁黑客远程破解逾25台特斯拉
-
近日,德国19岁的安全研究人员大卫·科伦坡(DavidColombo)表示,他在特斯拉的系统中发现一处系统漏洞,并通过该漏洞远程入侵了13个国家的25辆特斯拉电动汽车,使其关闭安全系统。他几乎掌控了...
- 朝鲜黑客使用已知恶意软件家族FASTCash的 Linux 变种来窃取资金
-
据观察,朝鲜威胁组织使用已知恶意软件家族FASTCash的Linux变种来窃取资金,作为以财务为动机的活动的一部分。一位自称HaxRob的安全研究员表示,这种恶意软件“安装在受感染网络内处理卡...
- Phorpiex恶意脚本卷土重来,成为LockBit 3.0勒索木马传播载体
-
IT之家5月5日消息,安全公司Cybereason发文透露“老牌”恶意脚本Phorpiex近日又卷土重来,成为传播LockBit3.0勒索木马的载体,感染了相应脚本的设备会自动下...
- 黑客远程入侵控制Jeep 自由光 互联网汽车存隐患
-
当我们在为汽车互联网技术带来的便捷欢呼雀跃时,也许危险也在悄悄走近。近日据Wired报道,名叫安迪的男子正开着Jeep自由光以70码的时速行驶在圣路易斯下城区时,车辆突然失去了控制。“首先是冷风突然调...
- 警惕!KeePass密码管理器竟成黑客“帮凶”
-
近日,网络安全领域爆出一则令人震惊的消息:网络安全公司WithSecure披露,在过去至少八个月的时间里,黑客通过篡改知名的KeePass密码管理器,上演了一场大规模的恶意攻击大戏!KeePass作...
- 开源网页应用框架ThinkPHP遭黑客滥用,变身远程代码执行工具
-
IT之家6月9日消息,安全公司Akamai近日发布报告,声称目前有黑客滥用一款热门开源网页应用框架ThinkPHP中的远程执行代码漏洞,打造了一款名为“Dama”的恶意工具进行攻击。I...
- 远程控制、窃密、挖矿!我国境内捕获“银狐”木马病毒变种
-
最近大家可得小心电脑病毒了!国家相关部门刚通报了一个叫"银狐"的木马病毒新变种,专门盯着普通老百姓和企事业单位下手。我给大家掰开揉碎了讲讲,遇到这种情况该怎么躲坑?·一、这病毒怎么盯上...
- 6款Linux常用远程连接工具,你最中意哪一款?
-
点击上方头像关注我,每周上午09:00准时推送,每月不定期赠送技术书籍。本文2106字,阅读约需6分钟Hi,大家好。远程连接的实现方法有很多,概括地说有两种,一种是用系统自带的远程连接,另外一种是用...
- 安全公司曝光黑客山寨杀毒软件Bitdefender官网,实为提供木马
-
IT之家5月31日消息,安全公司DomainTools发文,透露有黑客伪造网站声称提供杀毒软件,实则借机传播恶意木马。IT之家参考相应通报获悉,相应黑客首先建立山寨Bitdefender...
- 魔兽世界怀旧服:mc与bwl高手进阶输出手法与职业心得理解
-
作者:NGA-499917309a前言:之前写了两篇教新手术士怎么打mc和bwl的帖子,属于基础入门,只是让大家会打,随着时间推移,副本早已进入farm阶段,新手也不满足于会打,而是追求更高的输出,甚...
- 《奇幻梦境》进不去游戏解决方法攻略
-
奇幻梦境第一章近日发售了,本作也是一款第一人称解密游戏。本作的游戏画面色彩简单明了,包括了游戏的剧情也是。有不少的小伙伴反映奇幻梦境打不开不进不去,接下来小编就给大家解决这款游戏打不开进不去的一些可能...
- 国外网友热议:LOL客户端仍然如此差劲!新版又在测试了?
-
印象中英雄联盟的客户端换过几次版本,但是动作最大的应该就是在2017年的那次,直接更换了整个客户端的UI界面以及内部的很多组件。但是新版客户端上线至今两年多的时间里,玩家对于这个客户端的吐槽依旧很多,...
- 谷歌地球免费专业版7.1.5.1557下载
-
IT之家讯5月22日消息,谷歌地球专业版GoogleEarthPro已经更新到7.1.5.1557版,目前,谷歌官方还没有给出更新日志。这种情况通常来讲都是常规问题修复,建议新老用户及时下载安装...
- 僵尸部队三部曲 免安装中文硬盘版下载发布
-
【游戏封面】中文名称:僵尸部队三部曲游戏名称:ZombieArmytrilogy游戏类型:第三人称射击游戏制作:Rebellion游戏发行:Rebellion游戏发行:PC游民星空狙击精英3专区版...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- 远程桌面管理服务器的软件工具:Splashtop
- 最担心的事还是发生了 19岁黑客远程破解逾25台特斯拉
- 朝鲜黑客使用已知恶意软件家族FASTCash的 Linux 变种来窃取资金
- Phorpiex恶意脚本卷土重来,成为LockBit 3.0勒索木马传播载体
- 黑客远程入侵控制Jeep 自由光 互联网汽车存隐患
- 警惕!KeePass密码管理器竟成黑客“帮凶”
- 开源网页应用框架ThinkPHP遭黑客滥用,变身远程代码执行工具
- 远程控制、窃密、挖矿!我国境内捕获“银狐”木马病毒变种
- 6款Linux常用远程连接工具,你最中意哪一款?
- 安全公司曝光黑客山寨杀毒软件Bitdefender官网,实为提供木马
- 标签列表
-
- 如何绘制折线图 (52)
- javaabstract (48)
- 新浪微博头像 (53)
- grub4dos (66)
- s扫描器 (51)
- httpfile dll (48)
- ps实例教程 (55)
- taskmgr (51)
- s spline (61)
- vnc远程控制 (47)
- 数据丢失 (47)
- wbem (57)
- flac文件 (72)
- 网页制作基础教程 (53)
- 镜像文件刻录 (61)
- ug5 0软件免费下载 (78)
- debian下载 (53)
- ubuntu10 04 (60)
- web qq登录 (59)
- 笔记本变成无线路由 (52)
- flash player 11 4 (50)
- 右键菜单清理 (78)
- cuteftp 注册码 (57)
- ospf协议 (53)
- ms17 010 下载 (60)