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

相关文章

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

Redis 基本数据类型和使用详解

《Redis基本数据类型和使用详解》String是Redis最基本的数据类型,一个键对应一个值,它的功能十分强大,可以存储字符串、整数、浮点数等多种数据格式,本文给大家介绍Redis基本数据类型和... 目录一、Redis 入门介绍二、Redis 的五大基本数据类型2.1 String 类型2.2 Hash

分析 Java Stream 的 peek使用实践与副作用处理方案

《分析JavaStream的peek使用实践与副作用处理方案》StreamAPI的peek操作是中间操作,用于观察元素但不终止流,其副作用风险包括线程安全、顺序混乱及性能问题,合理使用场景有限... 目录一、peek 操作的本质:有状态的中间操作二、副作用的定义与风险场景1. 并行流下的线程安全问题2. 顺

Java Instrumentation从概念到基本用法详解

《JavaInstrumentation从概念到基本用法详解》JavaInstrumentation是java.lang.instrument包提供的API,允许开发者在类被JVM加载时对其进行修改... 目录一、什么是 Java Instrumentation主要用途二、核心概念1. Java Agent

Kotlin 协程之Channel的概念和基本使用详解

《Kotlin协程之Channel的概念和基本使用详解》文章介绍协程在复杂场景中使用Channel进行数据传递与控制,涵盖创建参数、缓冲策略、操作方式及异常处理,适用于持续数据流、多协程协作等,需注... 目录前言launch / async 适合的场景Channel 的概念和基本使用概念Channel 的

Python函数的基本用法、返回值特性、全局变量修改及异常处理技巧

《Python函数的基本用法、返回值特性、全局变量修改及异常处理技巧》本文将通过实际代码示例,深入讲解Python函数的基本用法、返回值特性、全局变量修改以及异常处理技巧,感兴趣的朋友跟随小编一起看看... 目录一、python函数定义与调用1.1 基本函数定义1.2 函数调用二、函数返回值详解2.1 有返

Java Stream流与使用操作指南

《JavaStream流与使用操作指南》Stream不是数据结构,而是一种高级的数据处理工具,允许你以声明式的方式处理数据集合,类似于SQL语句操作数据库,本文给大家介绍JavaStream流与使用... 目录一、什么是stream流二、创建stream流1.单列集合创建stream流2.双列集合创建str

MySQL的JDBC编程详解

《MySQL的JDBC编程详解》:本文主要介绍MySQL的JDBC编程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、前置知识1. 引入依赖2. 认识 url二、JDBC 操作流程1. JDBC 的写操作2. JDBC 的读操作总结前言本文介绍了mysq

Python ORM神器之SQLAlchemy基本使用完全指南

《PythonORM神器之SQLAlchemy基本使用完全指南》SQLAlchemy是Python主流ORM框架,通过对象化方式简化数据库操作,支持多数据库,提供引擎、会话、模型等核心组件,实现事务... 目录一、什么是SQLAlchemy?二、安装SQLAlchemy三、核心概念1. Engine(引擎)

Java Stream 并行流简介、使用与注意事项小结

《JavaStream并行流简介、使用与注意事项小结》Java8并行流基于StreamAPI,利用多核CPU提升计算密集型任务效率,但需注意线程安全、顺序不确定及线程池管理,可通过自定义线程池与C... 目录1. 并行流简介​特点:​2. 并行流的简单使用​示例:并行流的基本使用​3. 配合自定义线程池​示