boost::shared_future实现多线程并发操作的测试程序

177 篇文章 ¥59.90 ¥99.00
本文介绍了如何使用boost::shared_future在C++中实现多线程并发操作。通过示例展示了如何创建任务,使用packaged_task和shared_future在不同线程中执行,并获取结果,强调了确保局部变量生命周期的重要性。

boost::shared_future实现多线程并发操作的测试程序

boost::shared_future是一种非常有用的工具,它可以让我们在进行多线程并发操作时更加高效和方便。下面我们来看一下如何使用boost::shared_future实现一个简单的多线程并发操作的测试程序。

首先我们需要引入boost库

#include <boost/thread.hpp>
#include

using namespace boost;

然后我们定义一个函数fun,用于实现一些时间较长的操作

int fun(int n)
{
int sum = 0;
for (int i = 1; i <= n; ++i)
{
sum += i;
this_thread::sleep_for(chrono::seconds(1));
}
return sum;
}

接下来我们在主函数中定义两个任务f1和f2,并使用shared_future将其传递给线程进行多线程处理

int main()
{
// 定义任务f1
packaged_task<int(int)> task1(fun);
shared_future f1 = task1.get_future();
thread t1(move(task1), 5);

// 定义任务f2
packaged_task<int(int)> task2(fun);
sha
namespace beast = boost::beast; // from <boost/beast.hpp> namespace http = beast::http; // from <boost/beast/http.hpp> namespace net = boost::asio; // from <boost/asio.hpp> using tcp = boost::asio::ip::tcp; // from <boost/asio/ip/tcp.hpp> using TypeCallbackClientOnDone = std::function<void(const char*, const std::string&, const char*)>; // Performs an HTTP GET and prints the response class ClientSession : public std::enable_shared_from_this<ClientSession> { public: // Objects are constructed with a strand to // ensure that handlers do not execute concurrently. explicit ClientSession(net::io_context& ioc, std::shared_ptr<beast::tcp_stream> stream, const std::string& host, int port); // Start the asynchronous operation void Run(int timeout, char const* target, const char* contentType, const std::string& content, const TypeCallbackClientOnDone& cb); // 拿走其内的Stream std::shared_ptr<beast::tcp_stream> TakeStream(); private: void DoRun(int timeout, const std::string& target, const std::string& contentType, const std::string& content, const TypeCallbackClientOnDone& cb); void OnConnect(beast::error_code* ecPtr, int timeout); void OnWrite(beast::error_code ec, std::size_t bytes_transferred, int timeout); void OnRead(beast::error_code ec, std::size_t bytes_transferred, int timeout); void OnFail(const std::string& errMsg, char const* what); void ReportFail(const std::string& errMsg, char const* what); void CloseSocketAndConnect(int timeout); private: net::io_context& ioc_; std::shared_ptr<beast::tcp_stream> stream_; std::string host_; int port_{ 0 }; //用于底层连接复用,是否失败时重连 bool reconnect_{ true }; beast::flat_buffer buffer_; // (Must persist between reads) http::request<http::string_body> request_; http::response<http::string_body> res_; TypeCallbackClientOnDone funcOnDone_; }; 改用strand序列化
最新发布
07-24
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值