草庐IT

BOOST-ASIO

全部标签

c++ - boost ,使用 tcp 通过网络发送文件,首选方法?

在文档的boost示例中,tcp:iostream用于非常简单地通过网络发送流。在其他示例中,write()用于将数据写入套接字,而不是涉及更多代码。这两种方法有什么区别?优点和缺点?是否应该使用其他东西来代替? 最佳答案 我从未使用过boostAPI,所以读者要当心……;)tcp::iostream似乎允许您使用类似流的接口(interface)与套接字进行交互。这种方法抽象了与套接字编程相关的复杂性,因此它会更可取,特别是如果您不熟悉套接字编程。这对于基于TCP的数据共享非常有意义。如果您正在进行非常简单的数据交换,例如请求/响

boost - boost::asio tcp 套接字关闭是否阻塞?

boost::asioTCPsocketaccept/read/write均提供异步版本,但不提供关闭版本。在我的代码中,我只调用socket.close(),大多数时候它工作正常。它触发了正常的TCP关闭。但有时,close()只是关闭套接字而没有关闭TCP。结果,我不得不调用shutdown()来代替。但我不想阻止我的代码。shutdown()是否在boost:asio中阻塞?关闭()怎么样?close()是否阻塞? 最佳答案 首先,Boost.Asio中的shutdown()和close()调用调用底层的BSD套接字实现。因此

c++ - Boost::ASIO - 如何使用 2 个线程来处理接收和发送消息

我正在为Windows客户端使用Boost::ASIO版本1.52.0。我希望能够专用一个线程来处理所有从服务器接收的消息,然后另一个专用线程来处理所有传出到服务器的消息。我现在为两个线程使用相同的io_service对象。我担心的是,当io_service::run()方法被调用时,处理传出消息的线程可能会被安排处理一些传入消息调用,反之亦然-反之亦然。所以,我的问题-这可能吗?如果是,那么使用第二个io_service对象是否可以解决问题——每个线程一个?有没有更好的方法来设计这个?我试图避免对读取和写入处理程序使用多个线程。我想确认的另一件事是-我读到如果2个或更多async_r

c++ - 了解 TCP 数据包大小限制和 UDP 数据包大小限制及其在 boost::asio 编程级别的含义

我正在使用boost::asio在我的客户端应用程序和服务器应用程序中执行UDP以及TCP通信。我发现我只能使用UDP传输大小为65535字节的数据,因为它似乎是UDP中的最大数据包大小。TCP中也有最大数据包大小限制,即65535字节?但是我可以在TCP中使用boost::asio::write发送大于最大数据包大小的block,并在客户端应用程序上读取它。我看到我不必担心TCP中的最大数据包大小,但在UDP中我确保每个socket.send_to都使用小于maxpacketsize的缓冲区完成>这是如何工作的?这是因为TCP是基于流的,负责在较低层创建数据包吗?有什么方法可以增加U

c++ - boost asio : unable to acknowledge a file transfer

我正在使用boostasio通过TCP执行文件传输。文件传输有效,但是当我决定通过链接async_write(在服务器上)和async_read_until(在客户端上)实现从服务器到客户端的简单确认消息时,我观察到奇怪的行为:服务器端不再正确接收文件。在传输结束前几百个字节,服务器不再接收任何字节,因此永远不会调用负责确认文件传输的async_write。这似乎发生在我写完文件后在客户端调用async_read_until时。由于某种原因,它会影响当前的文件传输。客户端实现:#include"StdAfx.h"#include#include#include#include#incl

c++ - boost asio TCP 服务器必须绑定(bind)到 IP 地址?

我不确定自己是否正确使用了BOOSTASIO,我的代码如下,boost::asio::ip::tcp::resolverresolver(io_);boost::asio::ip::tcp::resolver::queryquery(std::string("127.0.0.1"),port);boost::asio::ip::tcp::endpointendpoint=*resolver.resolve(query);acceptor_.open(endpoint.protocol());它绑定(bind)到127.0.0.1。当客户端从外部连接时,客户端使用IP地址192.168.

c++ - 提升 asio receive() 与 read()

boost::asio::ip::tcp::socket有两种读取流的函数。我假设他们的语义不同。有人可以概述一下吗,我有文档lookedthrough没有澄清这一点。 最佳答案 正如文档中所说:Thereceive()operationmaynotreceivealloftherequestednumberofbytes.Considerusingtheread()functionifyouneedtoensurethattherequestedamountofdataisreadbeforetheblockingoperatio

c++ - 通过 boost tcp 传输文件

我想通过LAN通过tcp传输一些文件,所以我为我的TX-Part编写了以下代码:voidsend_data(char*filename,char*dest){try{boost::asio::io_serviceio_service;chardest_t=*dest;std::stringadr=ip_adr_display[0]+':'+boost::lexical_cast(PORTNUM_TCP_IN);std::cout和接收部分:voidrec_data(void){try{std::cout使用以下服务器和客户端代码:usingboost::asio::ip::tcp;cl

c++ - 通过 Boost TCP 发送大量数据?

我必须通过TCP从一台计算机向另一台计算机发送网格数据...这些网格可能相当大。我很难思考通过TCP发送它们的最佳方式是什么,因为我对网络编程知之甚少。这是我需要放入缓冲区以通过TCP发送的基本类结构:classPrimitiveCollection{std::vectorprimitives;};classPrimitive{PRIMTYPESprimType;//PRIMTYPESisjustanenumwithvaluesforfan,strip,etc...unsignedintnumVertices;std::vectorvertices;};classVertex{floa

c++ - Boost-asio 在单个 (TCP) 接受器上监听多个 IP 地址

boostTCP接受器可以通过使用端点构造函数连接起来,端点构造函数只接受端口号作为参数,在这种情况下,它将监听所有IP地址/NIC。是否有可能让接受者收听选定的IP地址?或者我是否必须为我感兴趣的每个IP地址创建一个接受器?查看文档,我找不到任何迹象表明这是可能的。我已经好几年没看过套接字API了,但我猜API并没有直接允许这样做。 最佳答案 有无限制的聆听和有限制的聆听。unbound意味着你听所有的NICs,绑定(bind)-到特定的一个。不可能选择一些NIC,我认为因为同样的情况可以通过为每个NIC提供专门的接受器来实现