gpt4 book ai didi

c++ - 如何使用C++标准库网络TS在服务器和客户端之间发送消息

转载 作者:行者123 更新时间:2023-12-01 18:02:24 32 4
gpt4 key购买 nike

我尝试按照 boost 的教程进行操作,但是 API 并不相同,所以我不得不猜测一些部分。

到目前为止我的尝试如下所示:

#include <iostream>
#include <experimental/internet>
#include <experimental/socket>
#include <thread>
#include <chrono>

using namespace std::experimental;

int main(int argc, char* argv[])
{

std::thread server = std::thread([]()
{
std::cout << "Starting server" << std::endl;

net::io_context context;
net::ip::tcp::endpoint endpoint{net::ip::tcp::v4(), 1234};
net::ip::tcp::acceptor acceptor{context, endpoint};
acceptor.non_blocking(true);
std::cout << "opened server on " << endpoint << std::endl;
std::error_code error;
net::ip::tcp::socket socket(context);
while (true)
{
socket = acceptor.accept(error); //accept connections
if (!error) //if connected with a client
{
std::cout << "Connected to client!" << std::endl;

std::this_thread::sleep_for(std::chrono::seconds(2));
std::string data = "Hello World!";
net::const_buffer buf(&data, sizeof(data));
socket.send(buf);
std::cout << "Sent data!" << std::endl;
while(true) {}
}
}
});


std::thread client = std::thread([]()
{
net::io_context context;
net::ip::tcp::socket socket(context);

net::ip::tcp::endpoint server{net::ip::tcp::v4(), 1234};
std::error_code error;
while(true)
{
socket.connect(server, error); //attempt to connect
if (!error) //if connected
{
std::cout << "Connected to server!" << std::endl;
net::mutable_buffer buf;
while(buf.size() == 0)
{
socket.receive(buf);
}
std::cout << "Received data!" << std::endl;
std::cout << buf.data() << std::endl;
while(true) {}
}
}

});

server.join();

return 0;
}

服务器和客户端连接,但客户端未收到消息。上面程序的输出是:

Starting server
opened server on 0.0.0.0:1234
Connected to server!
Connected to client!
Sent data!

然后就永远等待。

如何让socket正确接收数据?

最佳答案

这个

std::string data = "Hello World!";
net::const_buffer buf(&data, sizeof(data));

是错误的。您想要发送 data 字符串的内容,而不是其内部字节。 &data 为您提供指向字符串实例的基础数据的指针,而不是其内容。如果你想创建代表data内容的缓冲区,你可以这样做:

const std::string data = "Hello World!";
net::const_buffer buf = net::buffer(data);
<小时/>

这个

net::mutable_buffer buf;
while(buf.size() == 0)
{
socket.receive(buf);
}

给你无限循环,因为buf的初始大小是0,所以receive读取0个字节并返回。然后当检查条件时,buf的大小仍然为0,并且循环继续。

在调用receive之前,您需要指定缓冲区的大小 - 它指示必须读取多少字节。您正在发送 Hello World! 所以

std::string msg;
msg.resize(12); // prepare space for incoming data
net::mutable_buffer buf = net::buffer(msg);
socket.receive(buf);
std::cout << "I got: " << msg << std::endl;

关于c++ - 如何使用C++标准库网络TS在服务器和客户端之间发送消息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58272753/

32 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com