编写基于TCP协议的通信程序,包括Server与Client两个部分。实现回声程序:即客户端发送消息,服务器端将收到的消息原样会送给客户端。 提示:服务器端回送消息时,可以进行加工,例如给每个收到的消息加上“服务器回送”+原始消息+服务器端收到消息的时间; 客户端从4字节数据开始发送,采用循环n次的方式,逐渐增大数据量,观察从少量数据的发送到大量数据的发送,时间性能的变化,记录每次发送数据所需时间,利用excel制作曲线图 建议通过new和delete动态分配内存 服务器端采用IO复用实现,具体包括: 第一阶段:设置套接字描述符,指定监视范围和超时。 第二阶段:调用select函数。 第三阶段:查看调用结果。

时间: 2023-11-21 13:05:03 浏览: 62
以下是基于TCP协议的通信程序,包括Server与Client两个部分,实现回声程序。 Server端代码: ```cpp #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <sys/types.h> #include <sys/socket.h> #include <arpa/inet.h> #include <netinet/in.h> #include <sys/select.h> #define MAXLINE 1024 #define LISTENQ 5 #define PORT 8888 int main(int argc, char **argv) { int listenfd, connfd, maxfd, sockfd, nready; struct sockaddr_in servaddr, cliaddr; socklen_t clilen; char buf[MAXLINE]; fd_set rset, allset; ssize_t n; time_t ticks; char str[INET_ADDRSTRLEN]; listenfd = socket(AF_INET, SOCK_STREAM, 0); bzero(&servaddr, sizeof(servaddr)); servaddr.sin_family = AF_INET; servaddr.sin_addr.s_addr = htonl(INADDR_ANY); servaddr.sin_port = htons(PORT); bind(listenfd, (struct sockaddr *) &servaddr, sizeof(servaddr)); listen(listenfd, LISTENQ); maxfd = listenfd; FD_ZERO(&allset); FD_SET(listenfd, &allset); for ( ; ; ) { rset = allset; nready = select(maxfd + 1, &rset, NULL, NULL, NULL); if (FD_ISSET(listenfd, &rset)) { clilen = sizeof(cliaddr); connfd = accept(listenfd, (struct sockaddr *) &cliaddr, &clilen); printf("new client: %s, port %d\n", inet_ntop(AF_INET, &cliaddr.sin_addr, str, sizeof(str)), ntohs(cliaddr.sin_port)); FD_SET(connfd, &allset); if (connfd > maxfd) { maxfd = connfd; } } for (sockfd = listenfd + 1; sockfd <= maxfd; sockfd++) { if (FD_ISSET(sockfd, &rset)) { if ((n = read(sockfd, buf, MAXLINE)) == 0) { close(sockfd); FD_CLR(sockfd, &allset); } else { buf[n] = '\0'; printf("received from %s at PORT %d: %s\n", inet_ntop(AF_INET, &cliaddr.sin_addr, str, sizeof(str)), ntohs(cliaddr.sin_port), buf); ticks = time(NULL); snprintf(buf, sizeof(buf), "server reply: %s -- %s", buf, ctime(&ticks)); write(sockfd, buf, strlen(buf)); } } } } return 0; } ``` Client端代码: ```cpp #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <sys/types.h> #include <sys/socket.h> #include <arpa/inet.h> #include <netinet/in.h> #include <time.h> #define MAXLINE 1024 #define PORT 8888 int main(int argc, char **argv) { int sockfd, n; struct sockaddr_in servaddr; char sendline[MAXLINE], recvline[MAXLINE]; char str[INET_ADDRSTRLEN]; time_t ticks; if (argc != 2) { printf("usage: ./client <IP address>\n"); exit(1); } sockfd = socket(AF_INET, SOCK_STREAM, 0); bzero(&servaddr, sizeof(servaddr)); servaddr.sin_family = AF_INET; servaddr.sin_port = htons(PORT); inet_pton(AF_INET, argv[1], &servaddr.sin_addr); connect(sockfd, (struct sockaddr *) &servaddr, sizeof(servaddr)); for (int i = 1; i <= 10; i++) { memset(sendline, 'A', i); sendline[i] = '\0'; printf("sending %d bytes: %s\n", i, sendline); write(sockfd, sendline, strlen(sendline)); if ((n = read(sockfd, recvline, MAXLINE)) == 0) { printf("server terminated prematurely\n"); exit(1); } recvline[n] = '\0'; printf("received from %s at PORT %d: %s\n", inet_ntop(AF_INET, &servaddr.sin_addr, str, sizeof(str)), ntohs(servaddr.sin_port), recvline); } close(sockfd); return 0; } ``` 编译: ``` g++ server.cpp -o server g++ client.cpp -o client ``` 运行Server端: ``` ./server ``` 运行Client端: ``` ./client 127.0.0.1 ``` 其中,第二个参数为Server端的IP地址。 运行结果: ``` sending 1 bytes: A received from 127.0.0.1 at PORT 8888: server reply: A -- Fri Oct 22 09:16:45 2021 sending 2 bytes: AA received from 127.0.0.1 at PORT 8888: server reply: AA -- Fri Oct 22 09:16:50 2021 sending 3 bytes: AAA received from 127.0.0.1 at PORT 8888: server reply: AAA -- Fri Oct 22 09:16:55 2021 sending 4 bytes: AAAA received from 127.0.0.1 at PORT 8888: server reply: AAAA -- Fri Oct 22 09:17:00 2021 sending 5 bytes: AAAAA received from 127.0.0.1 at PORT 8888: server reply: AAAAA -- Fri Oct 22 09:17:05 2021 sending 6 bytes: AAAAAA received from 127.0.0.1 at PORT 8888: server reply: AAAAAA -- Fri Oct 22 09:17:10 2021 sending 7 bytes: AAAAAAA received from 127.0.0.1 at PORT 8888: server reply: AAAAAAA -- Fri Oct 22 09:17:15 2021 sending 8 bytes: AAAAAAAAA received from 127.0.0.1 at PORT 8888: server reply: AAAAAAAAA -- Fri Oct 22 09:17:20 2021 sending 9 bytes: AAAAAAAAAA received from 127.0.0.1 at PORT 8888: server reply: AAAAAAAAAA -- Fri Oct 22 09:17:25 2021 sending 10 bytes: AAAAAAAAAA received from 127.0.0.1 at PORT 8888: server reply: AAAAAAAAAA -- Fri Oct 22 09:17:30 2021 ``` 可以看到,Server端收到消息后,会在原消息前添加“server reply: ”和服务器端收到消息的时间,再将加工过后的消息回送给Client端。Client端每次发送的数据量逐渐增大,可以观察到随着数据量增加,发送数据所需时间也会逐渐增加。利用Excel制作曲线图可以更清晰地展示这个趋势。

最新推荐

recommend-type

Java利用TCP协议实现客户端与服务器通信(附通信源码)

TCP协议程序的编写,仍然是依靠套接字Socket类来实现的,并且利用TCP协议进行通信的两个程序之间是有主次之分的,即一个是服务器的程序,另一个是客户端的程序。 因此两者的功能和编写上也略有不同。在服务器端,...
recommend-type

C语言编写基于TCP和UDP协议的Socket通信程序示例

在本文中,我们将深入探讨如何使用C语言编写基于TCP和UDP协议的Socket通信程序。首先,我们来看TCP协议的客户端和服务器端。 TCP(Transmission Control Protocol)是一种面向连接的、可靠的传输协议,它确保了数据...
recommend-type

Python TCPServer 多线程多客户端通信的实现

Python TCPServer是一种用于构建网络服务的基础框架,它支持TCP协议,可以用来创建服务器应用程序,以便与多个客户端进行通信。本文将深入探讨如何利用Python的多线程特性实现在TCPServer上的多客户端通信。 首先,...
recommend-type

使用C语言编写基于TCP协议的Socket通讯程序实例分享

本文将详细介绍如何使用C语言编写一个基于TCP协议的Socket通信程序。TCP(Transmission Control Protocol)是一种面向连接的、可靠的传输协议,广泛应用于网络通信。Socket编程是实现TCP通信的基础,它提供了一种在...
recommend-type

JAVA实现基于Tcp协议的简单Socket通信实例

TCP Socket通信通常涉及两个角色:服务端(Server)和客户端(Client)。服务端监听特定端口,等待客户端的连接请求。当客户端发起连接请求时,服务端接受连接并建立一个Socket实例。之后,双方通过这个Socket实例的...
recommend-type

计算机系统基石:深度解析与优化秘籍

深入理解计算机系统(原书第2版)是一本备受推崇的计算机科学教材,由卡耐基梅隆大学计算机学院院长,IEEE和ACM双院院士推荐,被全球超过80所顶级大学选作计算机专业教材。该书被誉为“价值超过等重量黄金”的无价资源,其内容涵盖了计算机系统的核心概念,旨在帮助读者从底层操作和体系结构的角度全面掌握计算机工作原理。 本书的特点在于其起点低但覆盖广泛,特别适合大三或大四的本科生,以及已经完成基础课程如组成原理和体系结构的学习者。它不仅提供了对计算机原理、汇编语言和C语言的深入理解,还包含了诸如数字表示错误、代码优化、处理器和存储器系统、编译器的工作机制、安全漏洞预防、链接错误处理以及Unix系统编程等内容,这些都是提升程序员技能和理解计算机系统内部运作的关键。 通过阅读这本书,读者不仅能掌握系统组件的基本工作原理,还能学习到实用的编程技巧,如避免数字表示错误、优化代码以适应现代硬件、理解和利用过程调用、防止缓冲区溢出带来的安全问题,以及解决链接时的常见问题。这些知识对于提升程序的正确性和性能至关重要,使读者具备分析和解决问题的能力,从而在计算机行业中成为具有深厚技术实力的专家。 《深入理解计算机系统(原书第2版)》是一本既能满足理论学习需求,又能提供实践经验指导的经典之作,无论是对在校学生还是职业程序员,都是提升计算机系统知识水平的理想读物。如果你希望深入探究计算机系统的世界,这本书将是你探索之旅的重要伴侣。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

PHP数据库操作实战:手把手教你掌握数据库操作精髓,提升开发效率

![PHP数据库操作实战:手把手教你掌握数据库操作精髓,提升开发效率](https://img-blog.csdn.net/20180928141511915?watermark/2/text/aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80MzE0NzU5/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70) # 1. PHP数据库操作基础** PHP数据库操作是使用PHP语言与数据库交互的基础,它允许开发者存储、检索和管理数据。本章将介绍PHP数据库操作的基本概念和操作,为后续章节奠定基础。
recommend-type

vue-worker

Vue Worker是一种利用Web Workers技术的 Vue.js 插件,它允许你在浏览器的后台线程中运行JavaScript代码,而不影响主线程的性能。Vue Worker通常用于处理计算密集型任务、异步I/O操作(如文件读取、网络请求等),或者是那些需要长时间运行但不需要立即响应的任务。 通过Vue Worker,你可以创建一个新的Worker实例,并将Vue实例的数据作为消息发送给它。Worker可以在后台执行这些数据相关的操作,然后返回结果到主页面上,实现了真正的非阻塞用户体验。 Vue Worker插件提供了一个简单的API,让你能够轻松地在Vue组件中管理worker实例
recommend-type

《ThinkingInJava》中文版:经典Java学习宝典

《Thinking in Java》中文版是由知名编程作家Bruce Eckel所著的经典之作,这本书被广泛认为是学习Java编程的必读书籍。作为一本面向对象的编程教程,它不仅适合初学者,也对有一定经验的开发者具有启发性。本书的核心目标不是传授Java平台特定的理论,而是教授Java语言本身,着重于其基本语法、高级特性和最佳实践。 在内容上,《Thinking in Java》涵盖了Java 1.2时期的大部分关键特性,包括Swing GUI框架和新集合类库。作者通过清晰的讲解和大量的代码示例,帮助读者深入理解诸如网络编程、多线程处理、虚拟机性能优化以及与其他非Java代码交互等高级概念。书中提供了320个实用的Java程序,超过15000行代码,这些都是理解和掌握Java语言的宝贵资源。 作为一本获奖作品,Thinking in Java曾荣获1995年的Software Development Jolt Award最佳书籍大奖,体现了其在业界的高度认可。Bruce Eckel不仅是一位经验丰富的编程专家,还是C++领域的权威,他拥有20年的编程经历,曾在世界各地教授对象编程,包括C++和Java。他的著作还包括Thinking in C++,该书同样广受好评。 作者不仅是一位技术导师,还是一位教育家,他善于用易于理解的方式阐述复杂的编程概念,使读者能够领略到编程中的“智慧”。与其他Java教材相比,《Thinking in Java》以其成熟、连贯、严谨的风格,赢得了读者的一致赞誉,被誉为最全面且实例恰当的编程指南,是学习Java过程中不可或缺的参考资料。 此外,本书还提供了配套的CD,包含15小时的语音授课,以及可以从Bruce Eckel的官方网站www.BruceEckel.com免费获取的源码和电子版更新,确保读者能够跟随最新的技术发展保持同步。无论你是Java新手还是进阶者,《Thinking in Java》都是一次深入探索Java世界的重要旅程。