C++ boost库总结
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
第1章 Boost程序库总论
1.使用Boost,将大大增强C++的功能和表现力
第2章时间与日期
1.timer提供毫秒级的计时精度,内部是通过std::clock取时间的
2.progress_timer自动打印某生命周期的执行时间
3.原则上程序库的代码是不应该被用户修改的
4.progress_display可以在控制台上显示程序的执行进度
5.date_time库能很好的表示日期时间概念,并能和C的时间结构tm进行友好互转
6.date类提供年月日和星期几的概念。data可通过from_string或
from_undelimited_string从字符串解析而来,可通过to_simple_string、
to_iso_string、to_extended_iso_string转换为字符串。(精度到天的DateTime)
7.day_clock是精度到天的时钟
8.date_duration表示的是天精度的时间间隔概念,别名为days,另外还有years、
months、weeks
9.date_period表示两个date之间的日期区间(精度到天的TimeSpan)
10.date_iterator、week_iterator、month_iterator和year_iterator是时间的迭代
器
11.boost::greorian::gregorian_calendar中有实用静态方法:is_leap_year、
end_of_month_day
12.time_duration表示微妙或纳秒级的时间概念,几个实用子类:hours、minutes、
seconds、millisec/milliseconds、microsec/microseconds、nanosec/nannoseconds
13.duration_from_string可以从字符串解析time_duration
1.ptime用来表示时间点,相当于date和time_duration的组合。可以用
time_from_string或from_iso_string解析。(TimeSpan)
ptime now1 = second_clock::local_time(); intrusive_ptr是一个侵入式的引用计数型指针。当对内存占用的要求非常严格,或现存代码已经有了引用计数机制时
可以考虑。一般情况不推荐使用。
2.pool为固定块大小的类似malloc的原生内存分配器,支持数组式分配,一般情况
下不必对分配的内存调用free()。只分配原生内存,不调用构造函数,回收不调用析构函数,最好不要用于对象。
3.singleton_pool和pool接口完全一致,但为单件线程安全,同样要求编译期指定
要分配的原生内存块大小
4.object_pool为特定类型的对象池,不支持数组式分配,支持对象分配和对象原生
内存分配
5.pool_alloc和fast_pool_allocator是boost提供的两个STL分配器。除非有特别
需求,我们应该总使用STL实现自带的内存分配器。使用定制的分配器需要经过仔细的测试,以保证它与容器可以共同工作。
6.内存管理是C++程序开发中永恒的话题,因为没有GC,小心谨慎的管理内存等系统
资源是每一个C++程序员都必须面对的问题
第4章实用工具
1.private继承自noncopyable可以编译时禁止对象拷贝语法
2.C++静态强类型的优点有时候反而是阻碍程序员生产力的“缺陷”
3.typeof库使用宏模拟了C++0X中的typedef和auto关键字,可以减轻书写繁琐的
变量类型声明工作,简化代码。对于用户自定义类型需要手工用宏注册。(语法并没那么好看,不准备使用)
4.optional
始化”的概念(Nullable
5.optional
对象,但不能处理optional
6.optional
免大对象的拷贝开销
7.用于初始化的assign库(仅限于STL标准容器,通过重载“+=”和“,”运算符实
现):
#include
using namespace boost;
vector
set
map
8.assign还支持insert()、push_front()、push_back()(通过重载“()”实现):
vector
list
set
map
9.assign也可以将“()”和“,”混用:
vector
push_back(v), 1, 2, 3, 4, 5;
push_back(v)(6), 7, 64 / 8, (9), 10;
deque
push_front(d)() = "cpp", "java";
10.assign list_of()函数:
vector