C++ boost库总结(精心整理)

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 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

14.ptime用来表示时间点,相当于date和time_duration的组合。可以用

time_from_string或from_iso_string解析。(TimeSpan)

ptime now1 = second_clock::local_time(); // 得到本地当前秒精度时间

ptime now2 = microsec_clock::universal_time(); // 得到本地当前微秒精度时

15.time_period表示两个ptime之间的时间区间。(DateTime)

16.时间迭代器没有日期迭代器那么多,只有time_iterator一个

17.(boost时间日期库乱、破碎、过度设计)

第3章内存管理

1.scoped_ptr类似auto_ptr,但其一旦获得对象的管理权,你就无法再从它那里取回

来。该智能指针只希望在本作用域里使用,不希望被转让。auto_ptr有意设计成所

有权的自动转让,scoped_ptr有意设计成所有权的无法转让。scoped_ptr和

auto_ptr均不能作为容器元素。

2.scoped_array包装的是new[]产生的指针,并调用的是delete[]。往往是用来和C

代码保持兼容,一般不推荐使用

3.无论是编译器还是程序员都很难区分出new[]和new分配的空间,错误的运用delete

将导致资源异常

4.在C++历史上曾经出现过无数的引用计数型智能指针实现,但没有一个比得上

boost::shared_ptr,在过去、现在和将来,它都是最好的

5.shared_ptr支持的转型有:static_pointer_cast、const_pointer_cast

dynamic_pointer_cast,返回的结果是shared_ptr,并能保证这些指针的引用计数正确

6.用shared_ptr可以消除代码中显示的delete,用make_shared、allocate_shared

可以消除代码中显示的new

7.桥接模式(bridge)是一种结构型设计模式,它把类的具体实现细节对用户隐藏起来,

以达到类之间的最小耦合关系。在具体编程实践中桥接模式也被称为pimpl或者handle/body惯用法,它可以将头文件的依赖关系降到最小,减少编译时间,而且可以不使用虚函数实现多态

8.get_deleter(shared_ptr const& p)可以获得删除器。shared_ptr的删除器在

处理某些特殊资源时非常有用,它使得用户可以定制、扩展shared_ptr的行为,使其不仅仅能够管理内存资源,而是称为一个“万能”的资源管理工具

9.对应shared_ptr,也有一个shared_array,scoped_array和shared_array均不对

operator[]做下标检测

10.weak_ptr是为配合shared_ptr而引入的,更像是shared_ptr的一个助手而不是智

能指针,其没有重载operator*和->,不具有普通指针的行为。它最大的作用在于协助shared_ptr工作,像旁观者那样观测资源的使用情况

11.weak_ptr被设计为与shared_ptr共同工作,可以从一个shared_ptr或者另一个

weak_ptr对象构造,获得资源的观测权。但weak_ptr没有共享资源,它的构造不会引起指针引用计数的增加。同样,在weak_ptr析构时也不会导致引用计数的减少,它只是一个静静的观察者

12.获得this指针的shared_ptr,使对象自己能够产生shared_ptr管理自己:class T :

public enable_shared_from_this, then shared_ptr shared_from_this(). 13.intrusive_ptr是一个侵入式的引用计数型指针。当对内存占用的要求非常严格,

或现存代码已经有了引用计数机制时可以考虑。一般情况不推荐使用。

14.pool为固定块大小的类似malloc的原生内存分配器,支持数组式分配,一般情况

下不必对分配的内存调用free()。只分配原生内存,不调用构造函数,回收不调用析构函数,最好不要用于对象。

15.singleton_pool和pool接口完全一致,但为单件线程安全,同样要求编译期指定

要分配的原生内存块大小

16.object_pool为特定类型的对象池,不支持数组式分配,支持对象分配和对象原生

内存分配

相关文档
最新文档