之前用过了正则,可这台电脑没有安装,点击编译等了半天才编译完。我记得以前用命令配合参数就能很快的编译好,只怪自己没记录这些问题。
VC使用正则应该很多吧!方便嘛
首先到官网下载源码(https://sourceforge.net/projects/boost/files/boost/),目前最新版[1.67.0.beta.1]
下载的压缩包大小
解压后,找到bootstrap.bat 复制一份,删除原来的,写上:cmd.exe 保存。
直接打开bootstrap - 副本.bat 就启动到命令行了。
相关的参数含义:
stage 仅创建和安装库文件(不创建头文件),可以用 –stagedir= 选项指定库的安装位置,默认安装在当前目录下的stage文件夹内。
–with- 创建和安装指定的库,如果使用了这个选项,则仅仅指定的库被创建,其它库不被创建。如果不指定这个选项,默认创建所有需要编译安装的库。
link=static 指定生成静态regex库
threading=multi 指定生成多线程库
runtime-link=shared 指定动态链接C和C++ 运行库
更多详细的参数说明:
stage/install:stage表示只生成库(dll和lib),install还会生成包含头文件的include目录。本人推荐使用stage,因为install生成的这个include目录实际就是boost安装包解压缩后的boost目录(E:\SDK\boost\boost,只比include目录多几个非hpp文件,都很小),所以可以直接使用,而且不同的IDE都可以使用同一套头文件,这样既节省编译时间,也节省硬盘空间。
toolset:指定编译器,可选的如borland、gcc、msvc(VC6)、msvc-9.0(VS2008)等。
without/with:选择不编译/编译哪些库。因为python、mpi等库我都用不着,所以排除之。还有wave、graph、math、regex、test、program_options、serialization、signals这几个库编出的静态lib都非常大,所以不需要的也可以without掉。这可以根据各人需要进行选择,默认是全部编译。但是需要注意,如果选择编译python的话,是需要python语言支持的,应该到python官方主页http://www.python.org/下载安装。查看boost包含库的命令是bjam --show-libraries。
stagedir/prefix:stage时使用stagedir,install时使用prefix,表示编译生成文件的路径。推荐给不同的IDE指定不同的目录,如VS2008对应的是E:\SDK\boost\bin\vc9,VC6对应的是E:\SDK\boost\bin\vc6,否则都生成到一个目录下面,难以管理。如果使用了install参数,那么还将生成头文件目录,vc9对应的就是E:\SDK\boost\bin\vc9\include\boost-1_46\boost,vc6类似(光这路径都这样累赘,还是使用stage好)。
build-dir:编译生成的中间文件的路径。这个本人这里没用到,默认就在根目录(E:\SDK\boost)下,目录名为bin.v2,等编译完成后可将这个目录全部删除(没用了),所以不需要去设置。
link:生成动态链接库/静态链接库。生成动态链接库需使用shared方式,生成静态链接库需使用static方式。一般boost库可能都是以static方式编译,因为最终发布程序带着boost的dll感觉会比较累赘。
runtime-link:动态/静态链接C/C++运行时库。同样有shared和static两种方式,这样runtime-link和link一共可以产生4种组合方式,各人可以根据自己的需要选择编译。一般link只选static的话,只需要编译2种组合即可,即link=static runtime-link=shared和link=static runtime-link=static,本人一般就编这两种组合。
threading:单/多线程编译。一般都写多线程程序,当然要指定multi方式了;如果需要编写单线程程序,那么还需要编译单线程库,可以使用single方式。
debug/release:编译debug/release版本。一般都是程序的debug版本对应库的debug版本,所以两个都编译。
看完这些参数后自己大概知道要怎么编译了。
单独编译安装regex库:
bjam stage --with-regex link=static runtime-link=static threading=multi
我的工程是静态的,所以我编译静态库 link=static runtime-link=static
编译完了 会在boost_1_66_0\stage\lib下面生成4个静态库文件,从文件名就能分辨出来了
//-mt-sgd-x32 (-mt 多线程 -sgb 静态的DEBUG -x32 32位使用)
libboost_regex-vc120-mt-sgd-x32-1_66.lib
//-mt-sgd-x64 (-mt 多线程 -sgb 静态的DEBUG -x64 64位使用)
libboost_regex-vc120-mt-sgd-x64-1_66.lib
//-mt-s-x32 (-mt 多线程 -s 静态的RELEASE -x32 32位使用)
libboost_regex-vc120-mt-s-x32-1_66.lib
//-mt-s-x64 (-mt 多线程 -s 静态的RELEASE -x64 64位使用)
libboost_regex-vc120-mt-s-x64-1_66.lib
复制这两个32位的静态库到BoostDemo目录下
Boost demo代码:
#include <boost/regex.hpp> #ifdef _DEBUG #pragma comment(lib, "libboost_regex-vc120-mt-sgd-x32-1_66.lib") #else #pragma comment(lib, "libboost_regex-vc120-mt-s-x32-1_66.lib") #endif CString sUrl=NULL; CString sRelust = NULL; GetDlgItemText(IDC_EDIT1, sUrl); //获取网页源码 sRelust = GetHttpFileData(sUrl); //UTF转GB2312 ConvertUtf8ToGBK(sRelust); //BOOST库使用 std::string str = CT2A(sRelust); string sWebUrl; CString sMatchUrl; boost::regex expression("href=\"([^\"]+)\"[^>]*>(.*?)"); boost::smatch what; std::string::const_iterator start = str.begin(); std::string::const_iterator end = str.end(); int iItem=0; while (boost::regex_search(start, end, what, expression)) { sWebUrl = what[1]; sMatchUrl = sWebUrl.c_str(); m_list.AddString(sMatchUrl); start = what[1].second; }
好了,整个Boost的编译及使用都讲到了。