动态链接,静态链接动态链接的区别?
1动态链接、静态连接库就是把(lib)文件中用到的函数代码直接链接进目标程序,程序运行的时候不再需要其它的库文件;2、动态链接就是把调用的函数所在文件模块(DLL)和调用函数在文件中的位置等信息链接进目标程序,程序运行的时候再从DLL中寻找相应函数代码,因此需要相应DLL文件的支持。3、1 静态链接库的优点 (1) 代码装载速度快,执行速度略比动态链接库快; (2) 只需保证在开发者的计算机中有正确的.LIB文件,在以二进制形式发布程序时不需考虑在用户的计算机上.LIB文件是否存在及版本问题,可避免DLL地狱等问题。 2 动态链接库的优点 (1) 更加节省内存并减少页面交换;(2) DLL文件与EXE文件独立,只要输出接口不变(即名称、参数、返回值类型和调用约定不变),更换DLL文件不会对EXE文件造成任何影响,因而极大地提高了可维护性和可扩展性;(3) 不同编程语言编写的程序只要按照函数调用约定就可以调用同一个DLL函数;(4)适用于大规模的软件开发,使开发过程独立、耦合度小,便于不同开发者和开发组织之间进行开发和测试。
动态链接和静态链接的区别?
动态链接库和静态链接库一般是编译集成一系列的接口(函数)在程序源代码编译完成后通过编译器编译并通过链接器与这些库进行链接动态链接库与静态链接库的区别在于链接器在进行链接时静态库会被直接编译进程序里而动态链接库并不会,我们这里将这些链接库称作依赖(动态库和静态库)程序的运行需要这些依赖,程序在静态链接后该程序本身便已包含该依赖而动态链接后的程序本身本不包含该依赖,这些依赖需要执行者自行安装进操作系统(动态库、运行时库)程序运行时会动态地加载这些库linux上动态库一般的后缀后为.so静态库一般的后缀为.a由于静态链接会直接将库编译进程序里所以静态编译后的程序相较于动态链接所要大这就是因为静态链接会将链接库编译进程序里的原因,所以占用就要大了出于这种原因,静态库不易于维护与更新,如果链接库中有实现有bug等需要更新则需要更新整个程序,因为静态库被编译进程序中了但动态库就没有这种情况了,因为动态库是程序运行时动态加载的,所以我们只需要更新动态库而不需要更新所有依赖该库的程序(软件)另一方面,很多程序的开发都会使用到相同的链接库,也就是很多程序(软件)会有相同的依赖如果将这些依赖全部静态编译的话将会造成存储资源占用过多而造成资源浪费而使用动态库的方式这些程序(软件)则可以共享一个链接库,而不需要每个程序都带一个链接库,这样就大大地减少了存储资源占用空间
如何创建与调用动态链接库?
动态链接库:dll不必被包含在最终的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释放)方式。 所有库工程编译时必须Release方式: Build—set active configuration—选择库工程的release方式 示例: 一、 函数—-创建动态链接库(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的内部函数。