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

相关文章

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

ModelMapper基本使用和常见场景示例详解

《ModelMapper基本使用和常见场景示例详解》ModelMapper是Java对象映射库,支持自动映射、自定义规则、集合转换及高级配置(如匹配策略、转换器),可集成SpringBoot,减少样板... 目录1. 添加依赖2. 基本用法示例:简单对象映射3. 自定义映射规则4. 集合映射5. 高级配置匹

一文详解Java Stream的sorted自定义排序

《一文详解JavaStream的sorted自定义排序》Javastream中的sorted方法是用于对流中的元素进行排序的方法,它可以接受一个comparator参数,用于指定排序规则,sorte... 目录一、sorted 操作的基础原理二、自定义排序的实现方式1. Comparator 接口的 Lam

Java Stream的distinct去重原理分析

《JavaStream的distinct去重原理分析》Javastream中的distinct方法用于去除流中的重复元素,它返回一个包含过滤后唯一元素的新流,该方法会根据元素的hashcode和eq... 目录一、distinct 的基础用法与核心特性二、distinct 的底层实现原理1. 顺序流中的去重

SQL BETWEEN 语句的基本用法详解

《SQLBETWEEN语句的基本用法详解》SQLBETWEEN语句是一个用于在SQL查询中指定查询条件的重要工具,它允许用户指定一个范围,用于筛选符合特定条件的记录,本文将详细介绍BETWEEN语... 目录概述BETWEEN 语句的基本用法BETWEEN 语句的示例示例 1:查询年龄在 20 到 30 岁

mysql中insert into的基本用法和一些示例

《mysql中insertinto的基本用法和一些示例》INSERTINTO用于向MySQL表插入新行,支持单行/多行及部分列插入,下面给大家介绍mysql中insertinto的基本用法和一些示例... 目录基本语法插入单行数据插入多行数据插入部分列的数据插入默认值注意事项在mysql中,INSERT I

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