boost-thread

1. boost::thread是一个noncopyable的对象,其拷贝构造函数被设定为私有.

class BOOST_THREAD_DECL thread

{

private:

    thread(thread&);

    thread& operator=(thread&);

    ....

public:

    thread();

    ~thread();

};

2. 在使用thread的时候,一定要注意functor的作用域是否同thread对象保持一致,如果functor的作用域生命周期小于thread对象,那么系统可能会出现无法预期的结果

struct callable
{
    void operator()();
};

boost::thread oops()
{
    callable x;
    return boost::thread(boost::ref(x));
}// x is destroyed, but the newly-created thread still has a reference
  // this leads to undefined behaviour

3. interruption: boost::thread支持在运行以下的函数的线程中实现interruption:

• boost::thread::join()
• boost::thread::timed_join()
• boost::condition_variable::wait()
• boost::condition_variable::timed_wait()
• boost::condition_variable_any::wait()
• boost::condition_variable_any::timed_wait()
• boost::thread::sleep()
• boost::this_thread::sleep()
• boost::this_thread::interruption_point()
 一旦运行线程接受到interruption的命令,就会throw exception boost::thread_interrupted, 可以在线程中通过定义boost::this_thread::disable_interruption变量来实现禁止响应interruption。而在申明禁止响应interruption的作用域中可以通过定义boost::this_thread::restore_interruption来enable响应interruption。

4. 判断一个thread的instance是否有效的方法是判断其thread_id是否有效,函数thread::get_id()获得运行线程的id,如果其不等于thread::id()那么就表明这个thread的instance是有效的,反之是无效的。

 

5. boost::thread支持4种lock类型的concept:

  * Lockable: 拥有独占锁

  * TimedLockable: Lockable + 获取锁超时机制

  * SharedLockable: TimedLockable + 支持共享锁机制(multi-read & single-write)

  * Upgrade-Lockable: SharedLockable + 支持锁的属性在独占锁&共享锁之间切换。

 

6. boost::thread支持的lock type:

  * lock_guard: 支持Lockable类型的对象,使用RAII方式来实现lock/unlock

  * unique_lock: 既支持RAII方式的lock,也支持非RAII方式的lock(在lock函数显示的调用时才获得lock),还支持TimedLockable概念的lock,但是在调用析构函数的时候,将会释放所有的被占用的lock

  * shared_lock: 同unique_lock, 唯一的区别是仅仅支持SharedLockable概念的lock, 在lock/unlock过程中调用了lock_shared() / unlock_shared()

  * upgrade_lock: 同shared_lock, 唯一的区别是仅仅支持Upgrade-Lockable概念的lock, 在lock/unlock过程中调用了lock_upgrade() / unlock_upgrade()

 Note: 对于unique_lock/shared_lock/upgrade_lock都在constructor中支持3种不同的参数:

  * defer_lock_t的作用是在RAII之后不直接自动的调用lock函数,而是通过显示的调用lock函数来获得锁的所有权

  * try_to_lock_t的作用是在RAII的时候,调用try_lock, 无论能否获得锁,都返回

  * adopt_lock_t的作用是在RAII的时候,处理那些传入的mutex已经执行了lock操作而不需要重复执行的case。

 

7. boost::thread支持的mutex类型:

  * mutex: 一种Lockable概念的实现方式

  * timed_mutex: 一种TimedLockable概念的实现方式

  * recursive_mutex: 同mutex,但是同一个线程可以很多次的获得锁的所有权,通过reference_count来实现

  * recursive_timed_mutex:同timed_mutex, 但是同一个线程可以很多次的获得锁的所有权,通过reference_count来实现

  * shared_mutex: 一种UpgradeLockable概念的实现方式

 

8. One-time Initialization: 通过初始化变量boost::once_flag为BOOST_ONCE_INIT,同时使用call_once,来实现一个函数只在运行过程中被调用1次

 

9. barrier: 用于多线程之间的同步,最典型的用法是多线程中的每一个线程都执行到某一行code时,执行快的等待执行慢的,等到所有的相关线程都执行到这个点之后,才开始一起往下继续执行。

 

10. futures & promise: 它提供了一种获得结果的方式,这个结果可能在别的线程中计算,或者通过callback函数来实现,它的实现理念是通过异步的方式获得运行结果,必要的时候可以实现同步等待。其构成为:

 * boost::unique_future: 用于异步结果的获取。用于保存一个结果
 * boost::shared_future: 用于异步结果的获取。可用于保存多个结果

 * boost::packaged_task: 用于产生异步结果。用来wrap运行函数,或者functor,最终将函数或者functor的结果通知future。支持callback获得运行结果

 * boost::promise: 用于产生异步结果。不涉及到函数的运行,future监控promise的保存运行结果的变量,如果某一个线程将运行结果保存在promise的变量中,那么future就能够获得。支持callback获得运行结果


Boost C++ Libraries 是一组高质量的、经过同行评审的、开源的 C++ 库集合,旨在为 C++ 开发者提供广泛的支持。这些库设计为跨平台、可移植,并且可以与 C++ 标准库无缝集成。Boost 项目不仅提供库,还促进了 C++ 社区的发展,并影响了 C++ 标准的演进[^1]。 ### Boost 的主要特点 - **跨平台支持**:Boost 库可以在多个操作系统上运行,包括 Windows、Linux 和 macOS。 - **广泛的功能覆盖**:从算法、容器、函数对象到线程、系统操作、正则表达式等,Boost 提供了丰富的功能。 - **高质量与可维护性**:每个库都经过严格的测试和同行评审,确保代码质量。 - **与 C++ 标准兼容**:Boost 的许多库已被纳入 C++ 标准(如 C++11、C++14、C++17 等)。 ### 获取 Boost Boost 可以通过其官方网站 [boost.org](https://www.boost.org/) 获取。用户可以选择下载完整的源码包,或者通过包管理器安装(如 `apt`、`brew`、`vcpkg` 等)。 ```bash # 使用 apt 安装 Boost(适用于 Ubuntu/Debian) sudo apt-get install libboost-all-dev ``` ```bash # 使用 Homebrew 安装 Boost(适用于 macOS) brew install boost ``` ### 开发资源 1. **官方文档**:Boost 提供了详细的文档,涵盖每个库的使用方法、示例和 API 参考。可以通过 [Boost Documentation](https://www.boost.org/doc/) 访问。 2. **Boost GitHub 仓库**:Boost 的源码托管在 GitHub 上,开发者可以参与贡献代码或提交问题。[Boost GitHub](https://github.com/boostorg/boost) 3. **Boost 用户组和邮件列表**:Boost 社区活跃,用户可以通过邮件列表获取帮助或参与讨论。[Boost Mailing Lists](https://lists.boost.org/) 4. **书籍推荐**: - *《Boost C++ Application Development Cookbook》*:这本书提供了大量实用的 Boost 库使用示例,适合中级和高级 C++ 开发者。 - *《C++ Concurrency in Action》*:虽然不专门讨论 Boost,但该书深入探讨了 C++ 并发编程,而 Boost.Thread 是其重要参考。 ### 常见库介绍 - **Boost.Asio**:用于网络和低层 I/O 编程,支持异步操作和多线程。 - **Boost.Filesystem**:提供了对文件系统操作的支持,如路径、目录遍历等。 - **Boost.Thread**:用于多线程编程,提供了线程管理、互斥量、条件变量等工具。 - **Boost.Program_options**:用于解析命令行参数和配置文件。 - **Boost.Regex**:提供了正则表达式的支持,适用于字符串匹配和处理。 - **Boost.Serialization**:用于对象序列化,支持将对象保存为文件或通过网络传输。 ### 示例代码:使用 Boost.Asio 进行异步 TCP 通信 ```cpp #include <boost/asio.hpp> #include <iostream> using boost::asio::ip::tcp; int main() { boost::asio::io_context io; tcp::acceptor acceptor(io, tcp::endpoint(tcp::v4(), 12345)); for (;;) { tcp::socket socket(io); acceptor.accept(socket); std::cout << "Client connected\n"; char data[1024]; size_t len = socket.read_some(boost::asio::buffer(data)); std::cout.write(data, len); } return 0; } ``` 上述代码展示了如何使用 Boost.Asio 创建一个简单的 TCP 服务器,监听端口 12345 并接收客户端连接。 ### 构建 Boost 项目 要构建使用 Boost 的项目,通常需要配置 CMake 或 Makefile 来指定 Boost 的安装路径。以下是一个简单的 CMake 配置示例: ```cmake cmake_minimum_required(VERSION 3.10) project(boost_example) set(BOOST_ROOT "/path/to/boost") find_package(Boost REQUIRED COMPONENTS system filesystem) include_directories(${Boost_INCLUDE_DIRS}) add_executable(main main.cpp) target_link_libraries(main ${Boost_LIBRARIES}) ``` ### Boost 与现代 C++ 的关系 Boost 不仅是一个独立的库集合,还对 C++ 标准的发展产生了深远的影响。许多 Boost 库(如 Boost.ThreadBoost.SharedPtr 等)已经被纳入 C++11 标准,成为标准库的一部分。这表明 Boost 的设计理念和实现方式得到了广泛认可,并成为现代 C++ 编程的重要组成部分。 ### 开发者社区与贡献 Boost 拥有一个活跃的开发者社区,鼓励开发者参与贡献。无论是提交新库、修复 bug 还是改进文档,都可以通过 Boost 的 GitHub 仓库或邮件列表进行。此外,Boost 定期举办开发者会议(如 BoostCon),为开发者提供交流和学习的机会。 ---
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值