在Window和Linux下使用Zthread库
2020-11-19 18:19
标签:des class code tar http c ZThread库是一个开源的跨平台高级面向对象的线性和sycnchronization 库,以运行POSIX 和Win32 系统中的C++程序。 ZThread库的主页:http://zthread.sourceforge.net 最新版本Zthread远吗下载地址: http://prdownloads.sourceforge.net/zthread/ZThread-2.3.2.tar.gz ZThread文档:http://zthread.sourceforge.net/documentation.html 一、在Windows下使用ZThread 首先,下载ZThread,解压到某个目录下,我解压到D:\libs\ZThread-2.3.2\中。 方法1:包含源文件直接编译(不推荐) 1.在vs2010中,新建一个新的win32 控制台项目,选择空项目。 2.在源目录下新建一个main.cpp文件,在http://zthread.sourceforge.net/html/classZThread_1_1Thread.html 中复制一段示例代码拷贝到main.cpp中。 3.在项目的配置属性中,VC++目录的包含目录中增加ZThread的头文件目录,我这里是:D:\libs\ZThread-2.3.2\include。配置属性分DEBUG和RELEASE两个,默认选择的是DEBUG配置,但最好两个都配置一下,否则生成RELEASE版本时会报错 4.在项目中新建一个文件夹,名字随意,我的叫ZThread,然后选择这个文件夹,右键选择添加->现有项,将ZThread解压目录中的src目录的所有cxx文件都加入到这个目录中 然后现在可以编译了,正常来说,应该编译通过并且成功启动程序了。 但也有可能出现一些错误: 错误一:error C2664: “GetModuleHandleW”: 不能将参数 1 从“const char
[13]”转换为“LPCWSTR” 这个是由于vs2010的项目设置默认采用了unicode字符集导致的,可以在项目属性中将字符集改为多字节即可,也可以在GetModuleHandle函数的字符串参数加上_T()包含,改为GetModuleHandle(_T("Kernel32.dll")); 方法2:编译成静态库 1.在vs2010中,新建一个新的win32
控制台项目,我取名为ZThread.,项目类型选择为静态库。 2.在项目的配置属性中,VC++目录的包含目录中增加ZThread的头文件目录,我这里是:D:\libs\ZThread-2.3.2\include。配置属性分DEBUG和RELEASE两个,默认选择的是DEBUG配置,但最好两个都配置一下,否则生成RELEASE版本时会报错 3.在项目源目录中,右键选择添加->现有项,将ZThread解压目录中的src目录的所有cxx文件都加入到这个目录中 然后现在可以编译了,正常来说,应该编译通过并且成功生成了ZThread.lib静态库。 但也有可能出现一些错误: 错误一:error C2664: “GetModuleHandleW”: 不能将参数 1 从“const char
[13]”转换为“LPCWSTR” 这个是由于vs2010的项目设置默认采用了unicode字符集导致的,可以在项目属性中将字符集改为多字节即可,也可以在GetModuleHandle函数的字符串参数加上_T()包含,改为GetModuleHandle(_T("Kernel32.dll")); 静态库的使用方法是: 在我们的程序的工程属性的VC++目录的包含目录中,增加ZThread的头文件目录。 在程序代码中,增加#pragma comment(lib,
“ZThread.lib”)声明,同时,需要将ZThread.lib文件放在我们的源目录下,跟代码放一起。 方法3,编译成动态库DLL 跟方法2差不多,只不过项目类型选择为动态库。其他步骤一样,不再详述,编译成功后,会生成ZThread.lib,
ZThread.dll。 使用动态库的方法跟静态库一致,不同的是,使用动态库的程序在运行时需要ZThread.dll文件。 至此,静态链接库和动态链接库我们就说完了,我们做一下对比和补充: 两个lib文件的不同 我们发现,无论是静态链接库还是动态链接库,最后都有lib文件,那么两者区别是什么呢?其实,两个是完全不一样的东西。两个ZThread.lib大小都不同,静态库对应的lib文件叫静态库,动态库对应的lib文件叫导入库。实际上静态库本身就包含了实际执行代码、符号表等等,而对于导入库而言,其实际的执行代码位于动态库中,导入库只包含了地址符号表等,确保程序找到对应函数的一些基本地址信息。 对于静态链接库,我们在编译和链接的时候已经将所有的代码都导入进来,因此,当生成可执行文件以后,可执行文件包含所有的代码。因此,在可执行文件运行时就不再需要静态库了,这也是为什么我们删掉ZThread.lib程序照样执行;而对于动态链接库,实际上,可执行文件不包含DLL中的内容,只是通过导入库(.lib)知道了相应的地址信息,因此,可执行文件在运行时动态得去加载DLL,这也是为什么我们删掉ZThread.dll后程序就不能执行了。 对于DLL,我们是可以不要lib文件的。如果不要lib文件,我们可以通过函数指针的使用达到我们的目的。 二、在Linux下使用ZThread 在linux下,直接通过三部曲就可以完成了,非常简单 ./configure ./make ./make install 如果在make时遇到错误: ../include/zthread/Guard.h: In destructor ‘ZThread::Guard ../include/zthread/Guard.h:494: error: there are no arguments to
‘isDisabled‘ that depend on a template parameter, so a declaration of
‘isDisabled‘ must be available 只需 先export CXXFLAGS=-fpermissive,然后再执行 ./configure ./make ./make install 就可以了 在Window和Linux下使用Zthread库,搜素材,soscw.com 在Window和Linux下使用Zthread库 标签:des class code tar http c 原文地址:http://www.cnblogs.com/lidabo/p/3708664.html
文章标题:在Window和Linux下使用Zthread库
文章链接:http://soscw.com/index.php/essay/21974.html