NO.1

ASIO 读操作大总结:

A. Boos::asio::read 同步读方式

void client::read_data(char   * sourse  , int num )

{

  boost::asio::read( socket_own , boost::asio::buffer( sourse , num ) );

}

Buffer 可以换成 boost::streambuf

如:

boost::asio::streambuf response ;

boost::asio::read (socket, response );

而 streambuf 是能过自动扩充的 。

B. boost::asio::read_until 同步方式读, 但是读到特定的字符串后结束

例子;

boost::asio::streambuf response;

boost::asio::read_until(socket, response, "\r\n");

C: boost::asio::read_at 是在读的时候加上一个偏移量( I  thin k  )但是我用在socket的读写上没有成功, 可能用在其他device 上,  好吧,先不用你 。

俩个函数 ,

示例如下:

boost::array<char,

boost::asio::transfer_all(), ec);

if (ec)

{

// An error occurred.

}

else

{

// n == 128

}

同理:boost::array<char, 128> buf;

boost::system::error_code ec;

std::size_t n = boost::asio::read(

sock, boost::asio::buffer(buf),

boost::asio::transfer_at_least(64), ec);

if (ec)

{

// An error occurred.

}

else

{

// n >= 64 && n <= 128

}

其实以上就是实现了socket。Read_some 的作用 。

---------------------------------------------------------------------------------

D.重量出击 socke 成员函数 读操作

Socket. Receive ( boost::asio::buffer( buff ) );

利用receive的好处之一就是它既可以代替read 函数,同时还可以在后边加一个flag 参数 , 设置socket 的属性。

E: 更好使的是 socket.read_some ( boost::asio::buffer( buff ) ) ;

这个函数的神奇之处在于, 你在buffer中设置了比较大的缓冲区,这没有问题 , 它并不一定会把缓冲区填满才完成,而是读到eof 即完成操作,这样我们可以不必在关心server到底会发多少size_t 给client,我们 只管设置一个较大缓冲区, read_some 就知道读多少。它返回 std::size_t.

F: 以上介绍的都是同步方式操作的,下面是相对应的异步读操作。

如下是 boost::asio 命名空间下:

boost::bind( & client::handle_read ,this ,  boost::asio::placeholders::error , boost::asio::placeholders::bytes_transferred );boost::asio::async_read( socket_own , boost::asio::buffer ( data_copy ) ,

);

相对应的socket 的成员函数 异步操作如下:

void handler(示例如下:

const boost::system::error_code& error, // Result of operation.

std::size_t bytes_transferred           // Number of bytes read.

);

socket.async_read_some(boost::asio::buffer(data, size), handler);

很好的是, async_read_some 能够知道读多少数据, 所以我们的size可以尽可能的大一点,而 receive 的话可以保证读固定大小数据。

---------------------------------------------------------------------------------------

第二部分 写

ASIO 读操作大总结:

A. Boos::asio::write 同步写方式

void client::write_data(char   * sourse  , int num )

{

boost::asio::write( socket_own , boost::asio::buffer( sourse , num ) );

}

Buffer 可以换成 boost::streambuf

boost--asio--读写大总结的更多相关文章

  1. boost asio异步读写网络聊天程序client 实例具体解释

    boost官方文档中聊天程序实例解说 数据包格式chat_message.hpp <pre name="code" class="cpp">< ...

  2. boost asio异步读写网络聊天程序客户端 实例详解

    boost官方文档中聊天程序实例讲解 数据包格式chat_message.hpp <pre name="code" class="cpp">< ...

  3. boost asio tcp 多线程异步读写,服务器与客户端。

    // server.cpp #if 0 多个线程对同一个io_service 对象处理 用到第三方库:log4cplus, google::protobuf 用到C++11的特性,Windows 需要 ...

  4. boost::asio 的同、异步方式

    转自:http://blog.csdn.net/zhuky/archive/2010/03/10/5364574.aspx Boost.Asio是一个跨平台的网络及底层IO的C++编程库,它使用现代C ...

  5. boost::asio 使用 libcurl

    curl 使用 asio 的官方样例 http://curl.haxx.se/libcurl/c/asiohiper.html, 但这个例子用起来有很明细的 bug,asio 异步IO 只注册一次,也 ...

  6. Boost.Asio c++ 网络编程翻译(14)

    保持活动 假如,你须要做以下的操作: io_service service; ip::tcp::socket sock(service); char buff[512]; ... read(sock, ...

  7. 使用Boost.Asio编写通信程序

    摘要:本文通过形像而活泼的语言简单地介绍了Boost::asio库的使用,作为asio的一个入门介绍是非常合适的,可以给人一种新鲜的感觉,同时也能让体验到asio的主要内容. Boost.Asio是一 ...

  8. Boost.Asio的使用技巧

    基本概念 Asio proactor I/O服务 work类 run() vs poll() stop() post() vs dispatch() buffer类 缓冲区管理 I/O对象 socke ...

  9. Boost.Asio 网络编程([译]Boost.Asio基本原理)

    转自:https://m.w3cschool.cn/nlzbw/nlzbw-3vs825ya.html Boost.Asio基本原理 这一章涵盖了使用Boost.Asio时必须知道的一些事情.我们也将 ...

  10. boost.asio源码剖析(三) ---- 流程分析

    * 常见流程分析之一(Tcp异步连接) 我们用一个简单的demo分析Tcp异步连接的流程: #include <iostream> #include <boost/asio.hpp& ...

随机推荐

  1. C++ 文件保存

      文件保存: #include <sstream>#include <fstream>using namespace std; /*save to path ./record ...

  2. git status -s命令解析

    git status -s 以精简的方式显示文件状态. git status 输出的命令很详细,但有些繁琐. 如果用 git status -s 或 git status --short 命令,会得到 ...

  3. LGV 算法 (Lindström–Gessel–Viennot lemma)

    e(ai,bi)为从起点ai到终点bi的方案数.以上矩阵行列式结果就是(a1,a2,...an) 到 (b1,b2,...bn) 的所有不相交路径的种数. 具体证明的话看wiki,比较长.. 这个定理 ...

  4. SQL Server2012安装流程

    今天手比较抽风,把原来的SQL Server给卸载了,卸载还卸了半天,真是…… 安装时找了好多教程,结果都不是很详细,然后准备自己摸索一下,把这个过程记录下来,供大家参考,如果有不当的地方,欢迎指正, ...

  5. tomcat部署应用时设置context path为空的上下文路径问题

    在server.xml中添加<Context>元素,配置如下: <Context docBase="app" path="" reloadab ...

  6. Ajax和Json实现自动补全

    1.index.jsp <%@ page language="java" import="java.util.*" pageEncoding=" ...

  7. javascript获取值

    <div id='name'>张三</div> $('#name').val() $(name).val() 以上两个都可以得到值,第一种用的比较多.

  8. StarUML最新版2.8.1简单使用及代码生成

    StarUML(简称SU)是一款开放源码的UML开发工具,由韩国公司主导开发出来的,可以直接到StarUML网站下载. 在这里直接超链接:http://staruml.io/download SU是一 ...

  9. Nmap扫描基础常用命令(包含进阶使用)

    Nmap扫描常用命令  - Nmap scans common commands 1.扫描单个目标 nmap ip 如:nmap 192.168.0.101 2.扫描多个目标 nmap ip1 ip2 ...

  10. 给xen虚拟机添加硬盘分区格式化

    给xen虚拟机添加硬盘磁盘分区----xenserver .添加硬盘500G .fdisk -l #在虚拟机上查看一下是否添加上 .fdisk /dev/xvdb(n-p--w) #开始分区,xvdb ...