1、windows库的存在方式
1.1、静态库:不能被加载的程序,可以理解为目标程序的归档;*.lib。
1.2、动态库:是可以被加载的程序;*.dll。
2、静态库
2.1、静态库的特点
目标程序的归档;
静态库的代码会被嵌入到程序当中;
程序执行时不需要静态库存在;
致使程序很大。
2.2、C语言的静态库
2.2.1、创建静态库
创建Win32静态库项目,使用*.c文件建立项目。
2.2.2、添加静态库函数
2.2.3、在程序中将静态库导入
项目设置中可以添加lib文件;
或者使用关键字pragma。
#pragma comment(lib,"../Lib/Winclib.lib")
2.2.4、使用静态库提供的函数
在C语言程序中,直接使用函数即可。
2.2.5、实例,(使用项目设置链接编译输出目录等,将库文件输出在../Lib/下,执行程序输出在../Bin/下)
2.2.5.1、vc++6.0创建一个静态库项目,添加源文件winclib.c,代码如下
int C_Add( int nAdd1, int nAdd2 ){
return ( nAdd1 + nAdd2 );
} int C_Sub( int nSub1, int nSub2 ){
return ( nSub1 - nSub2 );
}
winclib.c
编译后为winclib.lib
2.2.5.2、vc++6.0创建一个win32控制台应用程序,添加源文件useclib.c,代码如下
//导入静态库;
#pragma comment(lib,"../Lib/Winclib.lib") int main( )
{
int nAdd = ;
int nSub = ; //使用静态库函数;
nAdd = C_Add( , );
nSub = C_Sub( , ); printf( "ADD:%d\n", nAdd );
printf( "SUB:%d\n", nSub ); return ;
}
useclib.c
注意,编译时会出现警告,但是不影响编译和连接;
编译后为uscclib.exe
2.3、C++语言的静态库
2.3.1、创建静态库
创建win32静态库项目,使用*.cpp文件建立项目。
2.3.2、添加静态库的函数
2.3.3、导入静态库
#pragma comment( lib, "../Lib/Wincpplib.lib")
2.3.4、定义库函数的原型
extern int CPP_Add(int nAdd1, int nAdd2 );
extern int CPP_Sub(int nSub1, int nSub2 );
2.3.5、使用库函数
2.3.6、实例
2.3.6.1、vc++6.0创建一个静态库项目,添加源文件wincpplib.cpp,代码如下
int CPP_Add( int nAdd1, int nAdd2 ){
return ( nAdd1 + nAdd2 );
} int CPP_Sub( int nSub1, int nSub2 ){
return ( nSub1 - nSub2 );
}
wincpplib.cpp
2.3.6.2、vc++6.0创建一个win32控制台应用程序,添加源文件usecpplib.cpp,代码如下
#include "stdafx.h" //导入C++的静态库;
#pragma comment( lib, "../Lib/Wincpplib.lib") int main()
{
int nAdd = CPP_Add( , );
int nSub = CPP_Sub( , ); printf( "ADD:%d\n", nAdd );
printf( "SUB:%d\n", nSub ); return ;
}
usecpplib.cpp
2.3.7、在C++文件中使用C源文件生成的库
注意:此时,需要看C源文件使用的是C编译器还是C++编译器来生成的库,
若是使用C编译器生成的库,需要额外加extern "C"代码;
若是使用C++编译器生成的库,可不需要加这样的代码。
如下:
extern "C" {
int C_Add(int nAdd1, int nAdd2 );
int C_Sub(int nSub1, int nSub2 );
}
vc++6.0创建一个win32控制台应用程序,添加源文件usecpplib.cpp,代码如下
#include "stdafx.h" //导入C++的静态库;
#pragma comment( lib, "../Lib/Wincpplib.lib") //导入C的静态库;
#pragma comment(lib,"../Lib/Winclib.lib") //定义函数原型;注意:extern可加可不加;
extern int CPP_Add(int nAdd1, int nAdd2 );
extern int CPP_Sub(int nSub1, int nSub2 );
//此时,extern必须使用;
extern "C" {
int C_Add(int nAdd1, int nAdd2 );
int C_Sub(int nSub1, int nSub2 );
} int main(int argc, char* argv[])
{
int nAdd = CPP_Add( , );
int nSub = CPP_Sub( , ); printf( "ADD:%d\n", nAdd );
printf( "SUB:%d\n", nSub ); int nAdd2 = C_Add( , );
int nSub2 = C_Sub( , ); printf( "ADD:%d\n", nAdd2 );
printf( "SUB:%d\n", nSub2 );
return ;
}
wincpplib.cpp
3、动态库
3.1、动态库的特点
可以提供模块化的方式,方便协调开发。
对源代码保护。
减少可执行文件的大小
提高代码的重用率。
3.2、动态库的基本使用方法
动态库的创建
加载动态库
获取并使用库函数、变量或类
释放动态库
3.3、函数的动态库
3.3.1、动态库的创建
创建DLL的项目
增加动态库的函数
导出动态库函数:需要使用__declspec(dllexport)代码。
3.3.2、动态库的使用
3.3.2.1、隐式链接
导入LIB
定义函数原型
使用函数
注意:这些库是Dll动态库的映射表。
大量的win32的API基本都是使用的隐式链接,如kernel32.lib、user32.lib、gdi32.lib
实例:
vc++6.0创建一个静态库项目,添加源文件DllFunc.cpp,代码如下
__declspec(dllexport) int Dll_Add( int nAdd1, int nAdd2 ){
return ( nAdd1 + nAdd2 );
} __declspec(dllexport) int Dll_Sub( int nSub1, int nSub2 ){
return ( nSub1 - nSub2 );
}
DllFunc.cpp
vc++6.0创建一个win32控制台应用程序,添加源文件CallDllFunc.cpp,代码如下
#include "stdafx.h" //隐式导入DLL的Lib文件;
#pragma comment( lib, "../Lib/dllfunc.lib") //定义函数原型;
int Dll_Add( int nAdd1, int nAdd2 );
int Dll_Sub( int nSun1, int nSub2 ); int main(int argc, char* argv[])
{
int nAdd = Dll_Add( , );
int nSub = Dll_Sub( , );
printf("Dll_Add:%d\n", nAdd );
printf("Dll_Sub:%d\n", nSub );
return ;
}
CallDllFunc.cpp
3.3.2.2、显示链接