ACE基本APISOCKET编程TCPACE_INET_Addr类ACE_SOCK_Acceptor类ACE_SOCK_Connector类ACE_SOCK_Stream

本文主要是介绍ACE基本APISOCKET编程TCPACE_INET_Addr类ACE_SOCK_Acceptor类ACE_SOCK_Connector类ACE_SOCK_Stream,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Tcp通信过程一般为如下步骤:
1.	服务器绑定端口,等待客户端连接。
2.	客户端通过服务器的ip和服务器绑定的端口连接服务器。
3.	服务器和客户端通过网络建立一条数据通路,通过这条数据通路进行数据交互。 常用API:
1.	ACE—INET_Addr 类。
ACE"地址"类ACE_Addr的子类,表示TCP/IP和UDP/IP的地址。它通常包含机器的ip
和端口信息,通过它可以定位到所通信的进程。
定义方式:
ACE_INET_Addr addlnfo(3000/'192.168.1.100");
常用方法.•
1.	 get_host_name	获取主机名
2.	get_ip_address	获取 ip 地址
3.	get_port_number	获取端 口 号
2.	ACE_SOCK_Acceptor 类。
服务期端使用,用于绑定端口和被动地接受连接。
常用方法:
l.open绑定端口
1.	accept建立和客户段的连接
2.	ACE_S〇CK_Connector 类。
客户端使用,用于主动的建立和服务器的连接。
常用方法:
l.	connect()	建立和服务期的连接。
3.	ACE_SOCK_Stream 类。
客户端和服务器都使用,表示客户段和服务器之间的数据通路。
常用方法:
l.	send ()	发送数据
2.	recv ()	接收数据
3_close()	关闭连接(实际上就是断开了 socket连接)。
代码示例: 下而例子演示了如何如何用ACE创建TCP通信的Server端。
#include "ace/SOCK一Acceptor.h"
#include "ace/SOCK一Stream.h"
#include "ace/INET_Addr.h"
#include "ace/OS.h"
#include <string>
#include <iostream> using namespace std; int main(int argc, char *argv[])
{
ACE_INET_Addr port_to」isten(3000); //绑定的端口 ACE_SOCK_Acceptor acceptor;
if (acceptor.open (port一tojisten, 1) == -1) //绑定端口 {
cout<<endl<<"bind port failn<<endl; return -1;
>
while(true)
{
ACE_SOCK一Stream peer; //和客户端的数据通路 ACE__Time_Value timeout (10, 0); if (acceptor.accept (peer) != -1) //建立和客户端的连接 {
cout<<endl<<endl<<"client connect. "<<endl; char buffer[1024]; ssize一t bytes一received;
ACE_INET_Addr raddr; peer.getjocal 一 addr(raddr); cout<<endl<<"local
portyciraddr.get一 host一 name()<<n\t"<<raddr.get_port_number()<<endl; while ((bytes一received =
peer.recv (buffer, sizeof(buffer))) != -1) //读取客户端发送的数据 {
peer.send(buffer, bytes_received); //对客户端发数据 
>
peer.close ();
>
>
return 0;
>
这个例子实现的功能很简单,服务器端绑定3000号端口,等待一个客户端的连接,然后将 从客户端读取的数据再次转发给客户端,也就是实现了一个EchoServer的功能。 相应的客户端程序也比较简单,代码如下:
#include <ace/S0CK—Stream.h>
#include <ace/S0CK 一 Con nector. h>
#include <ace/INET_Addr.h>
#include <ace/Time__Value.h>
#include <string>
#include <iostream> using namespace std; int main(int argc, char *argv[])
{
ACE_INET_Addr addr(3000,"127.0.0.1");
ACE—SOCK一Connector connector;
ACE一Time一Value timeout(5,0);
ACE一SOCK一Stream peer; if(connector.connect(peer,addr,&timeout) != 0)
{
cout<〈"connection failed !"<<endl; return 1;
>
cout<<"conneced !"<<endl; string s="hello world"; peer.send(s.c_str(),s.length()); //发送数据 cout<<endl<<"send:\t"<<s<<endl; ssize_t bc=0; //接收的字节数 char buf[1024];
bc=peer.recv(buf/1024,&timeout); //接收数据 if(bc>=0)
buf[bc]=,\0';
cout<<endl<<"rev:\t"<<buf<<endl;
>
peer.close();
return 0;

这篇关于ACE基本APISOCKET编程TCPACE_INET_Addr类ACE_SOCK_Acceptor类ACE_SOCK_Connector类ACE_SOCK_Stream的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1062133

相关文章

mapstruct中的@Mapper注解的基本用法

《mapstruct中的@Mapper注解的基本用法》在MapStruct中,@Mapper注解是核心注解之一,用于标记一个接口或抽象类为MapStruct的映射器(Mapper),本文给大家介绍ma... 目录1. 基本用法2. 常用属性3. 高级用法4. 注意事项5. 总结6. 编译异常处理在MapSt

MyBatis ResultMap 的基本用法示例详解

《MyBatisResultMap的基本用法示例详解》在MyBatis中,resultMap用于定义数据库查询结果到Java对象属性的映射关系,本文给大家介绍MyBatisResultMap的基本... 目录MyBATis 中的 resultMap1. resultMap 的基本语法2. 简单的 resul

Java 枚举的基本使用方法及实际使用场景

《Java枚举的基本使用方法及实际使用场景》枚举是Java中一种特殊的类,用于定义一组固定的常量,枚举类型提供了更好的类型安全性和可读性,适用于需要定义一组有限且固定的值的场景,本文给大家介绍Jav... 目录一、什么是枚举?二、枚举的基本使用方法定义枚举三、实际使用场景代替常量状态机四、更多用法1.实现接

git stash命令基本用法详解

《gitstash命令基本用法详解》gitstash是Git中一个非常有用的命令,它可以临时保存当前工作区的修改,让你可以切换到其他分支或者处理其他任务,而不需要提交这些还未完成的修改,这篇文章主要... 目录一、基本用法1. 保存当前修改(包括暂存区和工作区的内容)2. 查看保存了哪些 stash3. 恢

Java Stream.reduce()方法操作实际案例讲解

《JavaStream.reduce()方法操作实际案例讲解》reduce是JavaStreamAPI中的一个核心操作,用于将流中的元素组合起来产生单个结果,:本文主要介绍JavaStream.... 目录一、reduce的基本概念1. 什么是reduce操作2. reduce方法的三种形式二、reduce

MySQL基本查询示例总结

《MySQL基本查询示例总结》:本文主要介绍MySQL基本查询示例总结,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Create插入替换Retrieve(读取)select(确定列)where条件(确定行)null查询order by语句li

Python 异步编程 asyncio简介及基本用法

《Python异步编程asyncio简介及基本用法》asyncio是Python的一个库,用于编写并发代码,使用协程、任务和Futures来处理I/O密集型和高延迟操作,本文给大家介绍Python... 目录1、asyncio是什么IO密集型任务特征2、怎么用1、基本用法2、关键字 async1、async

Java使用Stream流的Lambda语法进行List转Map的操作方式

《Java使用Stream流的Lambda语法进行List转Map的操作方式》:本文主要介绍Java使用Stream流的Lambda语法进行List转Map的操作方式,具有很好的参考价值,希望对大... 目录背景Stream流的Lambda语法应用实例1、定义要操作的UserDto2、ListChina编程转成M

一文带你搞懂Redis Stream的6种消息处理模式

《一文带你搞懂RedisStream的6种消息处理模式》Redis5.0版本引入的Stream数据类型,为Redis生态带来了强大而灵活的消息队列功能,本文将为大家详细介绍RedisStream的6... 目录1. 简单消费模式(Simple Consumption)基本概念核心命令实现示例使用场景优缺点2

redis中使用lua脚本的原理与基本使用详解

《redis中使用lua脚本的原理与基本使用详解》在Redis中使用Lua脚本可以实现原子性操作、减少网络开销以及提高执行效率,下面小编就来和大家详细介绍一下在redis中使用lua脚本的原理... 目录Redis 执行 Lua 脚本的原理基本使用方法使用EVAL命令执行 Lua 脚本使用EVALSHA命令