当从一个套接字读写内容时候,需要一个缓存区来保存读取和写入数据。缓存区内存的必须比io操作的实际长,就是后释放
同步: receive(buffer(buff)); strcpy(buff,"0k"); send(buffer(buff));
异步:
1、aysnc_receive 内存冲突问题。申请固定内存大小,如果接收的数据过大内存会被释放,可能会拷贝到其他数据容器的内存中,或者存储其他数据,导致冲突。
解决冲突: 1、使用全局缓冲区 。2、创建一个缓冲区,然后操作结束时释放它。3、使用一个集合对象管理这些套接字和其他数据,比如缓冲区数组。
void on_read(char *ptr,const boost::system::error_code &err, std::size_t read_bytes){
delete[]ptr;
}
.....
char * buff = new char[512];
sock.async_receive(buffer,512),boost::bind(on_read,buff,_1,_2);
3、第三种方法 用共享指针实现:
struct shard_buffer{
boost::shared_array<char>buff; //保存实例拷贝,如果超出范围,shared_array<> 就被自动销毁。
int size;
shared_buffer(size_t size)::buff(new char[size]),size(size){}
mutable_buffer_1 asio_buff() const{ return buffer(buff.get(),size);
};
void on_read(char * ptr,const boost::system::error_code &err,std::size_t read_bytes){}
sock.asyn_receive(buff.asio_buff(),boost::bind(on_read,buff,_1,_2)); on_read超出范围,bind 对像被释放,同时共享指针也同步释放。