当前位置:首页 > C++ boost库总结
第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
dynamic_pointer_cast
6. 用shared_ptr可以消除代码中显示的delete,用make_shared、allocate_shared
可以消除代码中显示的new
7. 桥接模式(bridge)是一种结构型设计模式,它把类的具体实现细节对用户隐藏起来,
以达到类之间的最小耦合关系。在具体编程实践中桥接模式也被称为pimpl或者handle/body惯用法,它可以将头文件的依赖关系降到最小,减少编译时间,而且可以不使用虚函数实现多态
8. get_deleter(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
13. intrusive_ptr是一个侵入式的引用计数型指针。当对内存占用的要求非常严格,
或现存代码已经有了引用计数机制时可以考虑。一般情况不推荐使用。
14. pool为固定块大小的类似malloc的原生内存分配器,支持数组式分配,一般情况
下不必对分配的内存调用free()。只分配原生内存,不调用构造函数,回收不调用析构函数,最好不要用于对象。
15. singleton_pool和pool接口完全一致,但为单件线程安全,同样要求编译期指定
要分配的原生内存块大小
16. object_pool为特定类型的对象池,不支持数组式分配,支持对象分配和对象原生
内存分配
17. pool_alloc和fast_pool_allocator是boost提供的两个STL分配器。除非有特别
需求,我们应该总使用STL实现自带的内存分配器。使用定制的分配器需要经过仔细的测试,以保证它与容器可以共同工作。
18. 内存管理是C++程序开发中永恒的话题,因为没有GC,小心谨慎的管理内存等系
统资源是每一个C++程序员都必须面对的问题
第4章 实用工具
1. private继承自noncopyable可以编译时禁止对象拷贝语法 2. C++静态强类型的优点有时候反而是阻碍程序员生产力的“缺陷”
共分享92篇相关文档