简介:
Boost库是一个可移植、提供源代码的C++库,作为标准库的后备,是C++标准化进程的开发引擎之一。 Boost库由C++标准委员会库工作组成员发起,其中有些内容有望成为下一代C++标准库内容。在C++社区中影响甚大,是不折不扣的“准”标准库。Boost由于其对跨平台的强调,对标准C++的强调,与编写平台无关。大部分boost库功能的使用只需包括相应头文件即可,少数(如正则表达式库,文件系统库等)需要链接库。但Boost中也有很多是实验性质的东西,在实际的开发中实用需要谨慎。boost 在一些播放软件和音效中指增强,比如Bass Boost,低音增强。
Boost库是为C++语言标准库提供扩展的一些C++程序库的总称。
Boost库由Boost社区组织开发、维护。其目的是为C++程序员提供免费、同行审查的、可移植的程序库。Boost库可以与C++标准库完美共同工作,并且为其提供扩展功能。Boost库使用Boost License来授权使用,根据该协议,商业的非商业的使用都是允许并鼓励的。
Boost社区建立的初衷之一就是为C++的标准化工作提供可供参考的实现,Boost社区的发起人Dawes本人就是C++标准委员会的成员之一。在Boost库的开发中,Boost社区也在这个方向上取得了丰硕的成果。在送审的C++标准库TR1中,有十个Boost库成为标准库的候选方案。在更新的TR2中,有更多的Boost库被加入到其中。从某种意义上来讲,Boost库成为具有实践意义的准标准库。
可下载Boost C++ Libraries[1]安装boost库。大部分boost库功能的使用只需包括相应头文件即可,少数(如正则表达式库,文件系统库等)需要链接库。里面有许多具有工业强度的库,如graph库。
很多Boost中的库功能堪称对语言功能的扩展,其构造用尽精巧的手法,不要贸然的花费时间研读。Boost另外一面,比如Graph这样的库则是具有工业强度,结构良好,非常值得研读的精品代码,并且也可以放心的在产品代码中多多利用。
分类:
按照功能分类的Boost库列表
按照实现的功能,Boost可为大致归入以下20个分类,在下面的分类中,有些库同时归入几种类别。
1. 字符串和文本处理
a) Conversion
b) Format
c) IOStream
d) Lexical Cast
e) Regex
f) Spirit
g) String Algo
h) Tokenizer
i) Wave
j) Xpressive
2. 容器
a) Array
b) Bimap
c) Circular Buffer
d) Disjoint Sets
e) Dynamic Bitset
f) GIL
g) Graph
h) ICL
i) Intrusive
j) Multi-Array
k) Multi-Index
l) Pointer Container
m) Property Map
n) Property Tree
o) Unordered
p) Variant
3. 迭代器
a) GIL
b) Graph
c) Iterators
d) Operators
e) Tokenizer
4. 算法
a) Foreach
b) GIL
c) Graph
d) Min-Max
e) Range
f) String Algo
g) Utility
5. 函数对象和高阶编程
a) Bind
b) Function
c) Functional
d) Functional/Factory
e) Functional/Forward
f) Functional/Hash
g) Lambda
h) Member Function
i) Ref
j) Result Of
k) Signals
l) Signals2
m) Utility
6. 泛型编程
a) Call Traits
b) Concept Check
c) Enable If
d) Function Types
e) GIL
f) In Place Factory, Typed In Place Factory
g) Operators
h) Property Map
i) Static Assert
j) Type Traits
7. 模板元编程
a) Function Types
b) Fusion
c) MPL
d) Proto
e) Static Assert
f) Type Traits
8. 预处理元编程
a) Preprocessors
9. 并发编程
a) Asio
b) Interprocess
c) MPI
d) Thread
10. 数学和数字
a) Accumulators
b) Integer
c) Interval
d) Math
e) Math Common Factor
f) Math Octonion
g) Math Quaternion
? h) Math/Special Functions
i) Math/Statistical Distributions
j) Multi-Array
k) Numeric Conversion
l) Operators
m) Random
n) Rational
o) uBLAS
11. 排错和测试
a) Concept Check
b) Static Assert
c) Test
12. 数据结构
a) Any
b) Bitmap
c) Compressed Pair
d) Fusion
e) ICL
f) Multi-Index
g) Pointer Container
h) Property Tree
i) Tuple
j) Uuid
k) Variant
13. 图像处理
a) GIL
14. 输入输出
a) Asio
b) Assign
c) Format
d) IO State Savers
e) IOStreams
f) Program Options
g) Serialization
15. 跨语言混合编程
a) Python
16. 内存管理
a) Pool
b) Smart Ptr
c) Utility
17. 解析
a) Spirit
18. 编程接口
a) Function
b) Parameter
19. 杂项
a) Compressed Pair
b) Conversion
c) CRC
d) Date Time
e) Exception
f) Filesystem
g) Flyweight
h) Lexical Cast
i) Meta State Machine
j) Numeric Conversion
k) Optional
l) Polygon
m) Program Options
n) Scope Exit
o) Statechart
p) Swap
q) System
r) Timer
s) Tribool
t) Typeof
u) Units
v) Utility
w) Value Initialized
20. 编译器问题的变通方案
a) Compatibility
b) Config
Boost中比较有名气的有这么几个库:
Regex
正则表达式库
Spirit
LL parser framework,用C++代码直接表达EBNF
Graph
图组件和算法
Lambda
在调用的地方定义短小匿名的函数对象,很实用的functional功能
concept check
检查泛型编程中的concept
Mpl
用模板实现的元编程框架
Thread
可移植的C++多线程库
Python
把C++类和函数映射到Python之中
Pool
内存池管理
smart_ptr
5个智能指针,学习智能指针必读,一份不错的参考是来自CUJ的文章:
相关图书
编辑
基本信息
书名:Boost程序库完全开发指南:深入C++“准”标准库作者:罗剑锋 著
ISBN 978-7-121-11577-6
出版日期:2010年9月
定价:79.00元
开本:16开
页码:600 页
宣传语:
站在C++98的最高峰迎接C++0x的曙光
深入C++“准”标准库,Boost你的力量
内容简介
Boost是一个功能强大、构造精巧、跨平台、开源并且完全免费的C++程序库,有着“C++‘准’标准库”的美誉。
它由C++标准委员会部分成员所设立的Boost社区开发并维护,使用了许多现代C++编程技术,内容涵盖字符串处理、正则表达式、容器与数据结构、并发编程、函数式编程、泛型编程、设计模式实现等许多领域,极大地丰富了C++的功能和表现力,能够使C++软件开发更加简洁、优雅、灵活和高效。
本书基于Boost1.42版,介绍了其中的所有99个库,并且详细深入地讲解了其中数十个库,同时实现了若干颇具实用价值的工具类和函数,可帮助读者迅速理解掌握Boost的用法以及应用于实际的开发工作中。
本书内容丰富、结构严谨、详略得当、讲解透彻,带领读者领略了C++的最新前沿技术,相信会是每位C++程序员的必备工具书。
作者介绍
罗剑锋(网名Chrono),1996年就读于东北财经大学,1997年开始接触C/C++。1998年参加全国计算机等级考试,获高级程序员资质。2003年毕业于北京理工大学,获计算机专业硕士学位。目前供职于某部委下属软件公司,任项目经理,主要研究方向为C/C++、设计模式、密码学、数据库、嵌入式系统开发。业余爱好是阅读、欣赏音乐和旅游。
推荐序
最近一年我电话面试了数十位 C++ 应聘者,惯用的暖场问题是“工作中使用过 STL 的哪些组件?使用过 Boost 的哪些组件?”。得到的答案大多集中在 vector、map 和 shared_ptr。如果对方是在校学生,我一般会问问 vector 或 map 的内部实现、各种操作的复杂度以及迭代器失效的可能场景。如果是有经验的程序员,我还会追问 shared_ptr 的线程安全性、循环引用的后果及如何避免、weak_ptr 的作用等。如果这些都回答得不错,进一步还可以问问如何实现线程安全的引用计数,如何定制删除动作等等。这些问题让我能迅速辨别对方的 C++ 水平。
我之所以在面试时问到 Boost,是因为其中的许多组件确实可以用于编写可维护的产品代码。Boost 包含近百个程序库,其中不乏具有工程实用价值的佳品。每个人口味与技术背景不一样,对 Boost 的取舍也不一样。就我的个人经验而言,首先可以使用绝对无害的库,例如 noncopyable、scoped_ptr、static_assert 等,这些库的学习和使用都比较简单,容易入手。其次,有些功能自己实现起来并不困难,正好 Boost 里提供了现成的代码,那就不妨一用,比如date_time 和 circular_buffer 等。然后,在新项目中,对于消息传递和资源管理可以考虑采用更加现代的方式,例如用 function/bind 在某些情况下代替虚函数作为库的回调接口、借助shared_ptr实现线程安全的对象回调等等。这二者会影响整个程序的设计思路与风格,需要通盘考虑,如果正确使用智能指针,在现代 C++ 程序里一般不需要出现 delete 语句。最后,对某些性能不佳的库保持警惕,比如 lexical_cast。总之,在项目组成员人人都能理解并运用的基础上,适当引入现成的 Boost 组件,以减少重复劳动,提高生产力。
Boost 是一个宝库,其中既有可以直接拿来用的代码,也有值得借鉴的设计思路。试举一例:正则表达式库 regex 对线程安全的处理。
早期的 RegEx 类不是线程安全的,它把“正则表达式”和“匹配动作”放到了一个类里边。由于有可变数据,RegEx 的对象不能跨线程使用。如今的 regex 明确地区分了不可变(immutable)与可变(mutable)的数据,前者可以安全地跨线程共享,后者则不行。比如正则表达式本身(basic_regex)与一次匹配的结果(match_results)是不可变的;而匹配动作本身(match_regex)涉及状态更新,是可变的,于是用可重入的函数将其封装起来,不让这些数据泄露给别的线程。正是由于做了这样合理的区分,regex 在正常使用时就不必加锁。
Donald Knuth 在“Coders at Work”一书里表达了这样一个观点:如果程序员的工作就是摆弄参数去调用现成的库,而不知道这些库是如何实现的,那么这份职业就没啥乐趣可言。换句话说,固然我们强调工作中不要重新发明轮子,但是作为一个合格的程序员,应该具备自制轮子的能力。非不能也,是不为也。
C/C++ 语言的一大特点是其标准库可以用语言自身实现。C 标准库的 strlen、strcpy、strcmp 系列函数是教学与练习的好题材,C++ 标准库的 complex、string、vector 则是类、资源管理、模板编程的绝佳示范。在深入了解 STL 的实现之后,运用 STL 自然手到擒来,并能自动避免一些错误和低效的用法。
对于 Boost 也是如此,为了消除使用时的疑虑,为了用得更顺手,有时我们需要适当了解其内部实现,甚至编写简化版用作对比验证。但是由于 Boost 代码用到了日常应用程序开发中不常见的高级语法和技巧,并且为了跨多个平台和编译器而大量使用了预处理宏,阅读 Boost 源码并不轻松惬意,需要下一番功夫。另一方面,如果沉迷于这些有趣的底层细节而忘了原本要解决什么问题,恐怕就舍本逐末了。
Boost 中的很多库是按泛型编程的范式来设计的,对于熟悉面向对象编程的人而言,或许面临一个思路的转变。比如,你得熟悉泛型编程的那套术语,如concept、model、refinement,才容易读懂 Boost.Threads 的文档中关于各种锁的描述。我想,对于熟悉 STL 设计理念的人而言,这不是什么大问题。
在某些领域,Boost 不是唯一的选择,也不一定是最好的选择。比如,要生成公式化的源代码,我会首选用脚本语言写一小段代码生成程序,而不用 Boost.Preprocessor;要在 C++ 程序中嵌入领域特定语言,我会首选用 Lua 或其他语言解释器,而不用 Boost.Proto;要用 C++ 程序解析上下文无关文法,我会首选用 ANTLR 来定义词法与语法规则并生成解析器(parser),而不用 Boost.Spirit。总之,使用 Boost 时心态要平和,别较劲去改造 C++ 语言。把它有助于提高生产力的那部分功能充分发挥出来,让项目从中受益才是关键。
要学习 Boost,除了阅读其官方网站的文档、示例与源码之外,最好能有一本比较全面的中文书在手边随时翻阅。对于不谙英文的开发者,这更是可幸之至。您手上这本《Boost 程序库完全开发指南》是很好的使用指南与参考手册。作者由浅入深地介绍了 Boost 的大部分常用内容,能让读者迅速了解 Boost,并从中找到自己需要的部分。拿到这本书稿之后,我有粗有细地阅读了一遍,总体来看,作者水平很高,也相当务实,对 C++ 和 Boost 的理解与运用很到位,我从这本书学到了不少新知识。为此,我乐于向希望学习 Boost 程序库的开发者推荐这本靠谱的书。
须知“功不唐捐”,作为一名现代 C++ 程序员,在 Boost 上投入的精力定能获得回报。
陈硕
《代码大全》译者之一
2010年8月于中国·香港
前 言
屈指算来,接触C++语言至今已经有十余个年头了。回首往事,不禁感慨良多。
缘起
1996年我上大学最开始学的是Pascal,不得不说,Pascal严谨的程序风格确实很适合作为一门教学语言,然而用于实际开发就不那么合适了(直到出现Delphi)。由于当时学校并未开设C语言课程,因此在Pascal课程结束后我就买书自学C/C++语言,并在次年报名国家计算机水平考试,靠着一点点编程和考试的“天分”获得了高级程序员资质(当年很热衷考级考证,后来就“淡定”多了)。虽然有了资格证,但我仍然算是个C++的初学者,对于C++的认识还处于C的面向过程和简单的基于对象层次上。
新千年伊始我考入了北京理工大学就读研究生,因为跟导师做项目开始接触STL与C++标准库,大概是2005年从1.33版结识了Boost,这才真正领略了C++的精髓。那段时期Java和C#正在国内大行其道,C++则势单力薄,有关STL和C++标准的技术书籍寥寥无几,而讲解Boost的书更是为零,故对Boost的学习基本只能靠自己的摸索与实践。好在Boost自带的文档相当丰富(虽然看全英文的资料十分辛苦),而且源码也写得比较清晰规范,在熟悉了STL的基础上学习Boost倒也并不算太难。
但Boost的一个最大的特点就是“庞大”,功能组件众多,要想把它全部装进脑子里融会贯通基本上是不可能的,使用时需要经常查阅英文文档,相当的麻烦。因此,在学习的过程中,我逐渐产生了编写学习笔记的想法。一开始只是一个简单的纯文本文件,记录了一些使用经验的片断,随着积累的不断增加,纯文本形式已经不能够满足知识整理的需求了,于是我又把这些文字迁移到了Word文档里,把使用经验分类编目,加以较系统地归纳梳理。慢慢地,这份学习笔记居然有了上万字的规模,成为了一份很好的Boost备忘参考,在日常的开发工作中给了我很大的帮助——就像《设计模式》一书中所说的那样,捕获了很多使用Boost解决问题的实践经验,避免了重复发现。不过,这份资料一直是仅限于我个人使用,属于“自娱自乐”的作品,从未示人。
时间一晃到了2010年1月份的某天夜里,不知道是什么原因我忽然失眠了,躺在床上翻来覆去怎么也睡不着。突然,一个念头闯入了脑海:把Boost开发经验整理出版吧,让更多人能够分享这些知识,正所谓“独乐乐,与众乐乐,孰乐?”。这个大胆的想法的出现让我那天的失眠又延长了几个小时——关于书的各种构想在头脑中“肆虐横行”。
随后的几天里我就把这个想法付诸行动了,虽然以前也写过并发表很多文章,也在网上印刷了几本个人文集,但出版正式的书还是第一次。在把学习笔记进一步整理完善,编写出较完整的结构和一个样章后,我就开始联系出版社了。当初并没有多大的信心,毕竟我这个作者名不见经传,也没有什么资历、背景和名气(而且还是个“网盲”,从未跟随潮流开个人博客)。很幸运,发出的第一个E-mail就是电子工业出版社,而且编辑也在第一时间回复了我,这才给了我以持续写作完成全书的动力。
写作过程中我也进一步加深了对Boost的认识,澄清了许多原来未曾注意到的细节。原本只打算写20万字左右、三百多页,但写到中途才发现Boost库的博大精深远非当初的理解,也意识到了自己当初学习的肤浅。历经了近半年近乎不眠不休的努力,最终呈现给读者的是这本厚达500多页的图书,文字量是最初学习笔记的数十倍,内容也翔实丰满了很多——达成这个结果,我个人可以说是问心无愧了。
C++与Boost
C++较Java和C#等语言的一个最大不同在于它并非是由某个公司或个人把持的,它的真正发展动力来自于广大程序员。Boost就是这样的一个典范,它成功地填补了从C++98到C++0x这“失落的十年”间的空白,在竞争对手Java和C#不断更新版本新增特性的时候以库的形式极大地增强了C++的能力,使C++不至于因为标准规范的滞后而落后于时代,而且Boost还深层次挖掘了C++的潜力,开创了泛型编程、模板元编程、函数式编程等崭新的境界。
就个人来说,我比较喜欢的Boost版本有两个,分别是1.35和1.39:1.35版增加了asio、bimap、circular_buffer等许多重要组件,而1.39版则增加了signals2库,这两个版本都在我的工作用机上停留了相当长的时间。落笔之时,Boost已经更新到了1.43版,成长为了一个相当完善、全面、强大的C++程序库。可以毫不夸张地说,现在的C++程序员,如果不熟悉Boost,那么至少丧失了一半使用C++的好处,同时会多耗费数倍的开发精力和时间。
随着C++0x标准的即将来临,Boost程序库的发展也出现了加速的趋势,由原来间隔数月不定期更新版本,改为定期(每3个月左右)发布新版本,而且每个新版本都会包含大量极有价值的更新内容。因此,希望读者在阅读本书时及时访问Boost的官网(http:://www.boost. org),以便获取最新的版本。
感谢读者选择本书,再说一句真心的“套话”(笑):限于作者水平有限,书中错漏在所难免,敬请读者原谅、指正。
致谢
首先我要感谢整个C++群体,特别是:C++语言的发明者Bjarne Stroustrup博士——他给我们带来了美妙的C++;然后是Alexander Stepanov和C++标准委员会——他们把STL引入了C++,开创了C++的现代编程风格;以及Beman G.Dawes、Boost程序库的所有作者和Boost社区——他们为我们奉献了如此高水准的程序库。
其次我要感谢电子工业出版社博文视点公司,他们给了我这个把自己的开发经验出版成书的机会,在把潦草的个人学习笔记变成正式图书的过程中他们付出了艰辛的努力。还要感谢陈硕先生,他审阅了本书的部分手稿,提出了很多有价值的参考意见,并慨然为本书撰写序言。
接下来我要感谢我的家人:感谢我的父母和弟弟,他们永远是我生命中最重要的人;感谢我的妻子,她自始至终都支持我的写作,并担负了大部分照顾孩子的家务(虽然偶有怨言);还要对已满一岁半的女儿说声抱歉,为了写作本书,我已经牺牲了很多陪她玩耍的时间。
我还要感谢黄美华、冯薇、戚天龙、罗玉震、颜静、陈刚、张秋香、缪泽波等同事,长期的共事令我们建立了深厚的友谊。对后两位同事致以特别的感谢,他们对完成本书提供了大力的支持和帮助。
最后,感谢多年以来的好友岳大海、时吉斌、王峰,感谢我的中学老师邓英、杜爱芹、练鑫云、陈静,感谢我的研究生导师贾云得,以及所有在我成长过程中曾经给予我关心和帮助的朋友们!
罗剑锋
2010年6月7日 于 北京 王府井
目 录
第0章 导读 1
0.1 关于本书 1
0.2 读者对象 1
0.3 本书的术语与风格 2
0.4 本书的结构 3
0.5 如何阅读本书 5
第1章 Boost程序库总论 7
1.1 关于Boost 7
1.1.1 什么是Boost 7
1.1.2 安装Boost 8
1.1.3 使用Boost 8
1.2 关于STLport 9
1.2.1 什么是STLport 9
1.2.2 安装STLport 10
1.2.3 使用STLport 10
1.3 开发环境 10
1.3.1 STLport的编译方法 11
1.3.2 Boost的编译方法 11
1.3.3 VisualStudio 2005环境设置 15
第2章 时间与日期 17
2.1 timer库概述 17
2.2 timer 17
2.2.1 用法 18
2.2.2 类摘要 18
2.2.3 使用建议 19
2.3 progress_timer 20
2.3.1 用法 20
2.3.2 类摘要 21
2.3.3 扩展计时精度 21
2.4 progress_display 23
2.4.1 类摘要 24
2.4.2 用法 25
2.4.3 注意事项 26
2.5 date_time库概述 27
2.5.1 编译date_time库 27
2.5.2 date_time库的基本概念 28
2.6 处理日期 29
2.6.1 日期 29
2.6.2 创建日期对象 30
2.6.3 访问日期 31
2.6.4 日期的输出 32
2.6.5 与tm结构的转换 33
2.6.6 日期长度 34
2.6.7 日期运算 35
2.6.8 日期区间 36
2.6.9 日期区间运算 38
2.6.10 日期迭代器 39
2.6.11 其他功能 40
2.6.12 综合运用 40
2.7 处理时间 43
2.7.1 时间长度 43
2.7.2 操作时间长度 45
2.7.3 时间长度的精确度 46
2.7.4 时间点 48
2.7.5 创建时间点对象 48
2.7.6 操作时间点对象 49
2.7.7 与tm、time_t等结构的转换 50
2.7.8 时间区间 51
2.7.9 时间迭代器 51
2.7.10 综合运用 52
2.8 date_time库的高级议题 54
2.8.1 编译配置宏 55
2.8.2 格式化时间 55
2.8.3 本地时间 56
2.8.4 序列化 58
2.9 总结 58
第3章 内存管理 61
3.1 smart_ptr库概述 61
3.1.1 RAII机制 61
3.1.2 智能指针 62
3.2 scoped_ptr 63
3.2.1 类摘要 63
3.2.2 操作函数 64
3.2.3 用法 65
3.2.4 与auto_ptr的区别 66
3.3 scoped_array 67
3.3.1 类摘要 67
3.3.2 用法 68
3.3.3 使用建议 69
3.4 shared_ptr 69
3.4.1 类摘要 70
3.4.2 操作函数 70
3.4.3 用法 72
3.4.4 工厂函数 74
3.4.5 应用于标准容器 75
3.4.6 应用于桥接模式 76
3.4.7 应用于工厂模式 77
3.4.8 定制删除器 78
3.4.9 高级议题 80
3.5 shared_array 81
3.5.1 类摘要 81
3.5.2 用法 82
3.6 weak_ptr 82
3.6.1 类摘要 82
3.6.2 用法 83
3.6.3 获得this的shared_ptr 84
3.7 intrusive_ptr 85
3.8 pool库概述 85
3.9 pool 85
3.9.1 类摘要 86
3.9.2 操作函数 86
3.9.3 用法 87
3.10 object_pool 88
3.10.1 类摘要 88
3.10.2 操作函数 88
3.10.3 用法 89
3.10.4 使用更多的构造参数 90
3.11 singleton_pool 91
3.11.1 类摘要 91
3.11.2 用法 92
3.12 pool_alloc 93
3.13 总结 93
第4章 实用工具 95
4.1 noncopyable 95
4.1.1 原理 96
4.1.2 用法 96
4.2 typeof 97
4.2.1 动机 97
4.2.2 用法 99
4.2.3 向typeof库注册自定义类 100
4.2.4 高级议题 101
4.3 optional 101
4.3.1 “无意义”的值 101
4.3.2 类摘要 102
4.3.3 操作函数 102
4.3.4 用法 103
4.3.5 工厂函数 104
4.3.6 高级议题 105
4.4 assign 106
4.4.1 使用操作符+=向容器
增加元素 106
4.4.2 使用操作符()向容器
增加元素 107
4.4.3 初始化容器元素 108
4.4.4 减少重复输入 110
4.4.5 与非标准容器工作 111
4.4.6 高级用法 112
4.5 swap 113
4.5.1 原理 113
4.5.2 交换数组 114
4.5.3 特化std::swap 114
4.5.4 特化ADL可找到的swap 115
4.5.5 使用建议 116
4.6 singleton 116
4.6.1 boost.pool的单件实现 117
4.6.2 boost.serialzation的
单件实现 119
4.7 tribool 120
4.7.1 类摘要 121
4.7.2 用法 122
4.7.3 为第三态更名 122
4.7.4 输入输出 123
4.7.5 与optional
4.8 operators 125
4.8.1 基本运算概念 126
4.8.2 算术操作符的用法 127
4.8.3 基类链 129
4.8.4 复合运算概念 130
4.8.5 相等与等价 131
4.8.6 解引用操作符 133
4.8.7 下标操作符 134
4.8.8 高级议题 135
4.9 exception 136
4.9.1 标准库中的异常 137
4.9.2 类摘要 137
4.9.3 向异常传递信息 139
4.9.4 更进一步的用法 140
4.9.5 包装标准异常 142
4.9.6 使用函数抛出异常 143
4.9.7 获得更多的调试信息 144
4.9.8 高级议题 145
4.10 uuid 146
4.10.1 类摘要 147
4.10.2 用法 148
4.10.3 生成器 150
4.10.4 增强的uuid类 152
4.10.5 与字符串的转换 153
4.10.6 SHA1摘要算法 154
4.11 config 155
4.11.1 BOOST_STRINGIZE 155
4.11.2 BOOST_STATIC_
4.11.2 CONSTANT 155
4.11.3 禁止编译器警告 156
4.11.4 其他工具 157
4.12 utility 157
4.12.1 BOOST_BINARY 157
4.12.2 BOOST_CURRENT_
FUNCTION 158
4.13 总结 160
第5章 字符串与文本处理 163
5.1 lexical_cast 163
5.1.1 用法 164
5.1.2 异常bad_lexical_cast 165
5.1.3 对转换对象的要求 166
5.1.4 应用于自己的类 166
5.2 format 167
5.2.1 简单的例子 168
5.2.2 输入操作符% 169
5.2.3 类摘要 171
5.2.4 格式化语法 172
5.2.5 format的性能 173
5.2.6 高级用法 173
5.3 string_algo 175
5.3.1 简单的例子 175
5.3.2 string_algo概述 176
5.3.3 大小写转换 177
5.3.4 判断式(算法) 178
5.3.5 判断式(函数对象) 179
5.3.6 分类 180
5.3.7 修剪 181
5.3.8 查找 182
5.3.9 替换与删除 184
5.3.10 分割 186
5.3.11 合并 187
5.3.12 查找(分割)迭代器 188
5.4 tokenizer 189
5.4.1 类摘要 190
5.4.2 用法 190
5.4.3 分词函数对象 191
5.4.4 char_separator 192
5.4.5 escaped_list_separator 193
5.4.6 offset_separator 193
5.4.7 tokenizer库的缺陷 195
5.5 xpressive 196
5.5.1 两种使用方式 197
5.5.2 正则表达式语法简介 197
5.5.3 类摘要 199
5.5.4 匹配 201
5.5.5 查找 203
5.5.6 替换 204
5.5.7 迭代 206
5.5.8 分词 207
5.5.9 与regex的区别 208
5.5.10 高级议题 209
5.6 总结 211
第6章 正确性与测试 213
6.1 assert 213
6.1.1 基本用法 213
6.1.2 禁用断言 214
6.1.3 扩展用法 215
6.1.4 BOOST_VERIFY 216
6.2 static_assert 217
6.2.1 用法 217
6.2.2 使用建议 218
6.3 test 219
6.3.1 编译test库 219
6.3.2 最小化的测试套件 220
6.3.3 单元测试框架简介 221
6.3.4 测试断言 222
6.3.5 测试用例与套件 223
6.3.6 测试实例 224
6.3.7 测试夹具 226
6.3.8 测试日志 228
6.3.9 运行参数 229
6.3.10 函数执行监视器 230
6.3.11 程序执行监视器 233
6.3.12 高级议题 234
6.4 总结 236
第7章 容器与数据结构 239
7.1 array 239
7.1.1 类摘要 240
7.1.2 操作函数 240
7.1.3 用法 241
7.1.4 能力限制 242
7.1.5 array的初始化 242
7.1.6 实现ref_array 243
7.1.7 ref_array的用法 244
7.2 dynamic_bitset 245
7.2.1 类摘要 245
7.2.2 创建与赋值 247
7.2.3 容器操作 248
7.2.4 位运算与比较运算 249
7.2.5 访问元素 249
7.2.6 类型转换 251
7.2.7 集合操作 251
7.2.8 综合运用 252
7.3 unordered 253
7.3.1 散列集合简介 254
7.3.2 散列集合的用法 255
7.3.3 散列映射简介 256
7.3.4 散列映射的用法 256
7.3.5 性能比较 257
7.3.6 高级议题 259
7.4 bimap 261
7.4.1 类摘要 261
7.4.2 基本用法 262
7.4.3 值的集合类型 263
7.4.4 集合类型的用法 264
7.4.5 使用标签类型 266
7.4.6 使用assign库 267
7.4.7 查找与替换 268
7.4.8 投射 269
7.4.9 高级议题 270
7.5 circular_buffer 271
7.5.1 类摘要 271
7.5.2 用法 272
7.5.3 环型缓冲区 273
7.5.4 空间优化型缓冲区 275
7.6 tuple 275
7.6.1 最简单的tuple:pair 276
7.6.2 类摘要 276
7.6.3 创建与赋值 277
7.6.4 访问元素 278
7.6.5 比较操作 279
7.6.6 输入输出 280
7.6.7 连结变量 281
7.6.8 应用于assign库 282
7.6.9 应用于exception库 282
7.6.10 内部结构 282
7.6.11 使用访问者模式 284
7.6.12 高级议题 285
7.7 any 287
7.7.1 类摘要 287
7.7.2 访问元素 288
7.7.3 用法 289
7.7.4 简化的操作函数 290
7.7.5 保存指针 291
7.7.6 输出 292
7.7.7 应用于容器 294
7.8 variant 294
7.8.1 类摘要 294
7.8.2 访问元素 295
7.8.3 用法 296
7.8.4 访问器 297
7.8.5 与any的区别 300
7.8.6 高级议题 300
7.9 multi_array 302
7.9.1 类摘要 302
7.9.2 用法 304
7.9.3 多维数组生成器 306
7.9.4 改变形状和大小 307
7.9.5 创建子视图 308
7.9.6 适配普通数组 310
7.9.7 高级议题 311
7.10 property_tree 314
7.10.1 类摘要 315
7.10.2 读取配置信息 316
7.10.3 写入配置信息 318
7.10.4 更多用法 319
7.10.5 XML数据格式 320
7.10.6 其他数据格式 321
7.10.7 高级议题 323
7.11 总结 324
第8章 算法 327
8.1 foreach 327
8.1.1 用法 328
8.1.2 详细解说 329
8.1.3 使用typeof 329
8.1.4 更优雅的名字 330
8.1.5 支持的序列类型 331
8.1.6 一个小问题 332
8.2 minmax 332
8.2.1 用法 333
8.2.2 使用tuples::tie 334
8.3 minmax_element 334
8.3.1 用法 334
8.3.2 其他函数的用法 335
8.4 总结 336
第9章 数学与数字 337
9.1 integer 337
9.1.1 integer_traits 337
9.1.2 标准整数类型 339
9.1.3 整数类型模板类 341
9.2 rational 344
9.2.1 类摘要 344
9.2.2 创建与赋值 345
9.2.3 算术运算与比较运算 346
9.2.4 类型转换 346
9.2.5 输入输出 347
9.2.6 分子与分母 347
9.2.7 与数学函数配合工作 347
9.2.8 异常 348
9.2.9 rational的精度 348
9.2.10 实现无限精度的整数类型 348
9.2.11 最大公约数和最小公倍数 353
9.3 crc 353
9.3.1 类摘要 354
9.3.2 预定义的实现类 354
9.3.3 计算CRC 355
9.3.4 CRC函数 356
9.3.5 自定义CRC函数 357
9.4 random 357
9.4.1 伪随机数发生器 358
9.4.2 伪随机数发生器的构造 359
9.4.3 伪随机数发生器的拷贝 360
9.4.4 随机数分布器 360
9.4.5 随机数分布器类摘要 361
9.4.6 随机数分布器用法 363
9.4.7 变量发生器 364
9.4.8 产生随机数据块 365
9.4.9 真随机数发生器 367
9.4.10 实现真随机数发生器 368
9.5 总结 369
第10章 操作系统相关 371
10.1 io_state_savers 371
10.1.1 类摘要 372
10.1.2 用法 372
10.1.3 简化new_progress_timer 374
10.2 system 374
10.2.1 编译system库 375
10.2.2 错误值枚举 375
10.2.3 错误类别 376
10.2.4 错误代码 377
10.2.5 错误异常 379
10.3 filesystem 380
10.3.1 编译filesystem库 380
10.3.2 类摘要 381
10.3.3 路径表示 383
10.3.4 可移植的文件名 384
10.3.5 路径处理 385
10.3.6 异常 387
10.3.7 文件状态 388
10.3.8 文件属性 390
10.3.9 文件操作 391
10.3.10 迭代目录 392
10.3.11 实例1:实现查找文件
10.3.11 功能 394
10.3.12 实例2:实现模糊查找
10.3.12 文件功能 395
10.3.13 实例3:实现拷贝目录
10.3.13 功能 397
10.3.14 文件流操作 399
10.4 program_options 400
10.4.1 编译program_options库 400
10.4.2 概述 401
10.4.3 选项值 403
10.4.4 选项描述器 404
10.4.5 选项描述器的用法 405
10.4.6 分析器 407
10.4.7 存储器 409
10.4.8 使用位置选项值 409
10.4.9 分析环境变量 411
10.4.10 分组选项信息 412
10.4.11 高级用法 414
10.5 总结 417
第11章 函数与回调 419
11.1 result_of 419
11.1.1 原理 420
11.1.2 用法 422
11.2 ref 422
11.2.1 类摘要 423
11.2.2 基本用法 424
11.2.3 工厂函数 425
11.2.4 操作包装 425
11.2.5 综合应用 426
11.2.6 为ref增加函数调用功能 427
11.3 bind 429
11.3.1 工作原理 429
11.3.2 绑定普通函数 430
11.3.3 绑定成员函数 432
11.3.4 绑定成员变量 433
11.3.5 绑定函数对象 433
11.3.6 使用ref库 434
11.3.7 高级议题 435
11.4 function 437
11.4.1 类摘要 437
11.4.2 function的声明 438
11.4.3 操作函数 439
11.4.4 比较操作 440
11.4.5 用法 440
11.4.6 使用ref库 441
11.4.7 用于回调 442
11.4.8 与typeof的区别 445
11.5 signals2 445
11.5.1 类摘要 446
11.5.2 操作函数 447
11.5.3 插槽的连接与调用 448
11.5.4 信号的返回值 449
11.5.5 合并器 450
11.5.6 管理信号的连接 452
11.5.7 更灵活的管理信号连接 453
11.5.8 自动连接管理 455
11.5.9 应用于观察者模式 457
11.5.10 高级议题 460
11.6 总结 465
第12章 并发编程 467
12.1 thread 467
12.1.1 编译thread库 468
12.1.2 使用thread库 468
12.1.3 时间功能 469
12.1.4 互斥量 469
12.1.5 线程对象 472
12.1.6 创建线程 473
12.1.7 操作线程 475
12.1.8 中断线程 476
12.1.9 线程组 479
12.1.10 条件变量 480
12.1.11 共享互斥量 484
12.1.12 future 485
12.1.13 高级议题 488
12.2 asio 493
12.2.1 概述 493
12.2.2 定时器 494
12.2.3 定时器用法 495
12.2.4 网络通信简述 498
12.2.5 IP地址和端点 499
12.2.6 同步socket处理 500
12.2.7 异步socket处理 502
12.2.8 查询网络地址 506
12.2.9 高级议题 507
12.3 总结 511
第13章 编程语言支持 513
13.1 python库概述 513
13.1.1 Python语言简介 514
13.1.2 安装Python环境 515
13.1.3 编译python库 515
13.1.4 使用python库 516
13.2 嵌入Python 517
13.2.1 初始化解释器 517
13.2.2 封装Python对象 518
13.2.3 执行Python语句 520
13.2.4 异常处理 521
13.3 扩展Python 522
13.3.1 最简单的例子 523
13.3.2 导出函数 525
13.3.3 导出重载函数 526
13.3.4 导出类 528
13.3.5 导出类的更多细节 530
13.3.6 高级议题 532
13.4 总结 534
第14章 其他Boost组件 537
14.1 字符串和文本处理 537
14.2 容器与数据结构 538
14.3 迭代器 539
14.4 函数对象与高级编程 539
14.5 泛型编程 540
14.6 模板元编程 541
14.7 预处理元编程 542
14.8 并发编程 542
14.9 数学与数字 543
14.10 TR1实现 543
14.11 输入输出 544
14.12 杂项 544
14.13 总结 546
第15章 Boost与设计模式 547
15.1 创建型模式 547
15.2 结构型模式 549
15.3 行为模式 552
15.4 其他模式 555
15.5 总结 556
第16章 结束语 559
16.1 未臻完美的Boost 559
16.2 让Boost工作得更好 560
16.3 工夫在诗外 563
附录A 推荐书目 565
附录B 网络资源 567
附录C C++标准简述 569
附录D STL简述 571
附录E ref_array实现代码 573