久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

如何將 boost asio tcp 套接字傳遞給線程以將心跳發(fā)

How to pass a boost asio tcp socket to a thread for sending heartbeat to client or server(如何將 boost asio tcp 套接字傳遞給線程以將心跳發(fā)送到客戶端或服務(wù)器)
本文介紹了如何將 boost asio tcp 套接字傳遞給線程以將心跳發(fā)送到客戶端或服務(wù)器的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧!

問題描述

我正在用 boost TCP 編寫一個客戶端/服務(wù)器程序,其中我想每 2 秒向客戶端發(fā)送一次 HEARTBEAT 消息,我正在嘗試創(chuàng)建一個新線程,通過它我可以輕松地發(fā)送它但無法解決它.我正在使用 boost::thread t(hearbeatSender,sock); 創(chuàng)建線程.但給出了很多錯誤.我也使用 bind 將函數(shù)名與套接字綁定,但沒有解決錯誤.

I am writing a client/server program in boost TCP in which I want to send a HEARTBEAT message to the client every 2 seconds for which I am trying to create a new thread by which I can send it easily but unable to solve it. I am creating thread using boost::thread t(hearbeatSender,sock); this. but giving lots of errors. I also use bind to bind function name with the socket but not resolved the error.

void process(boost::asio::ip::tcp::socket & sock);
std::string read_data(boost::asio::ip::tcp::socket & sock);
void write_data(boost::asio::ip::tcp::socket & sock,std::string);
void hearbeatSender(boost::asio::ip::tcp::socket & sock);
int main()
{

    unsigned short port_num = 3333;
    boost::asio::ip::tcp::endpoint ep(boost::asio::ip::address_v4::any(), port_num);
    boost::asio::io_service io;
    try
    {
        boost::asio::ip::tcp::acceptor acceptor(io, ep.protocol());
        acceptor.bind(ep);
        acceptor.listen();
        boost::asio::ip::tcp::socket sock(io);
        acceptor.accept(sock);
        boost::thread t(hearbeatSender,sock); 
        process(sock);
        t.join();

    }
    catch (boost::system::system_error &e)
    {
        std::cout << "Error occured! Error code = " << e.code()
        << ". Message: " << e.what();

        return e.code().value();
    }
  return 0;

}
void process(boost::asio::ip::tcp::socket & sock)
{
    while(1){
    std::string data = read_data(sock);
    std::cout<<"Client's request is: "<<data<<std::endl;
    write_data(sock,data);
    }
}
std::string read_data(boost::asio::ip::tcp::socket & sock)
{
    boost::asio::streambuf buf;
    boost::asio::read_until(sock, buf, "
");
    std::string data = boost::asio::buffer_cast<const char*>(buf.data());
    return data;
}
void write_data(boost::asio::ip::tcp::socket & sock,std::string data)
{
    boost::system::error_code error;
    std::string msg;
    int ch = data[0]-'0';
    switch(ch)
    {
        case 1: msg = "Case 1
"; break;
        case 2: msg = "Case 2
"; break;
        case 3: msg = "Case 3
"; break;
        case 4: msg = "Case 4
"; break;
        default: msg  = "Case default
"; break;
    }
    boost::asio::write( sock, boost::asio::buffer(msg+ "
"), error );
     if( !error ) {
        std::cout << "Server sent hello message!" << std::endl;
     }
     else {
        std::cout << "send failed: " << error.message() << std::endl;
     }
}
void hearbeatSender(boost::asio::ip::tcp::socket & sock)
{
    boost::system::error_code error;
    std::string msg = "HEARTBEAT";
    while(1)
    {
        sleep(2);
        std::cout<<msg<<std::endl;
        boost::asio::write( sock, boost::asio::buffer(msg+ "
"), error );
        if( !error ) {
        std::cout << "Server sent HEARTBEAT message!" << std::endl;
        }
        else {
            std::cout << "send failed: " << error.message() << std::endl;
        }
    }
}

這是一個服務(wù)端代碼,用于響應(yīng)客戶端的消息并向客戶端發(fā)送心跳.這是一個同步 TCP 服務(wù)器.

This is a server-side code for responding to the message of the client and sending heartbeat to the client. This is a synchronous TCP server.

推薦答案

代替這個:

try
    {
        boost::asio::ip::tcp::acceptor acceptor(io, ep.protocol());
        acceptor.bind(ep);
        acceptor.listen();
        auto sock = acceptor.accept();
        std::thread t([&sock]() {
            hearbeatSender(sock);
        });
        process(sock);
        t.join();

    }

使用它:

try{
        boost::asio::ip::tcp::acceptor acceptor(io, ep.protocol());
        acceptor.bind(ep);
        acceptor.listen();
        boost::asio::ip::tcp::socket sock(io);
        acceptor.accept(sock);

        std::thread t([&sock]() {
            hearbeatSender(sock);
        });
        process(sock);
        t.join();
}

還包括頭文件:

#include <thread>
#include <chrono>

(可選)你也可以使用 this_thread::sleep_for 而不是 sleep()std::this_thread::sleep_for(std::chrono::seconds(10));

(Optional) you can also use this_thread::sleep_for instead of sleep() std::this_thread::sleep_for(std::chrono::seconds(10));

把socket傳遞給線程的問題解決了.

The problem of passing a socket to the thread is solved.

現(xiàn)在,用于在客戶端和服務(wù)器之間進(jìn)行 HEARTBEAT 對話.可以從這里檢查完整的代碼:

Now, for conversing a HEARTBEAT between a client and a server. Complete code can be checked from here:

客戶端代碼 HEARTBEAT 每 5 次傳輸秒

服務(wù)器代碼,用于響應(yīng)客戶

這篇關(guān)于如何將 boost asio tcp 套接字傳遞給線程以將心跳發(fā)送到客戶端或服務(wù)器的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網(wǎng)!

【網(wǎng)站聲明】本站部分內(nèi)容來源于互聯(lián)網(wǎng),旨在幫助大家更快的解決問題,如果有圖片或者內(nèi)容侵犯了您的權(quán)益,請聯(lián)系我們刪除處理,感謝您的支持!

相關(guān)文檔推薦

Assertion failed (size.widthgt;0 amp;amp; size.heightgt;0)(斷言失敗(size.width0 amp;amp; size.height0))
Rotate an image in C++ without using OpenCV functions(在 C++ 中旋轉(zhuǎn)圖像而不使用 OpenCV 函數(shù))
OpenCV: process every frame(OpenCV:處理每一幀)
Why can#39;t I open avi video in openCV?(為什么我不能在 openCV 中打開 avi 視頻?)
OpenCV unable to set up SVM Parameters(OpenCV 無法設(shè)置 SVM 參數(shù))
Convert a single color with cvtColor(使用 cvtColor 轉(zhuǎn)換單一顏色)
主站蜘蛛池模板: 国产精品久久久亚洲 | 欧美一级片在线看 | 久久久一区二区三区 | 亚洲精品一区二区三区在线观看 | 国产精品久久久久久久久免费樱桃 | 国产福利观看 | 一区二区三区欧美大片 | 男女免费观看在线爽爽爽视频 | 国产欧美一级二级三级在线视频 | 国产超碰人人爽人人做人人爱 | av色在线| 91精品国产综合久久久久久丝袜 | 国产激情一区二区三区 | 日本一区二区三区四区 | www.99热| 黄色网址免费看 | 亚洲视频 欧美视频 | 成人在线视频免费观看 | 黄色在线免费网站 | a黄视频 | 午夜在线影院 | 第四色影音先锋 | 国产日韩久久 | 国产成人精品一区二区三 | 国产 91 视频 | 日韩电影一区 | 日韩欧美一级精品久久 | 国产a视频| 成人永久免费 | 日韩1区2区| 国产高清无av久久 | 九色视频网站 | 日韩中文字幕一区二区 | 色网在线播放 | 国产精品免费看 | 黄色片亚洲| 国产人久久人人人人爽 | 91不卡在线 | 九九久视频 | 欧美日韩精品一区 | 精品国产久 |