C++小程序:同一路由器下两台计算机间简单通信(2/2)——客户端

2024-05-12 20:52

本文主要是介绍C++小程序:同一路由器下两台计算机间简单通信(2/2)——客户端,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

       客户端的程序结构前半部分与服务器端基本相同,后半部分也相对简单。相关函数的解释可以参考前文服务器端的内容。有关客户端的内容除个别地方外,就不再做长篇大论的解释。强调一点,如果将此程序移到其它电脑上运行,编译需要release模式,具体做法可以参考上一篇。
      客户端程序简介如下:
      一、头文件部分

#include<iostream>
using namespace std;
#include<thread>
#include <WinSock2.h>         
#pragma comment(lib,"ws2_32.lib")
#pragma warning (disable: 4996) //解决C4996报错问题

    二、声明函数及全局变量

void clientRecv();
void clientSend();
SOCKET pubServerSock; //服务器端SOCKET对象(客户端需与服务器端联系)

    三、主函数编写(客户端与服务器端链接的具体步骤)

int main(void)
{

   步骤1. 窗口设置

	system("color 1A");system("title Client Station");system("mode con cols=60 lines=30");

   步骤2. 打开网络库

	WORD wdVersion = MAKEWORD(2, 2); WSADATA wdSockMsg;int nRes = WSAStartup(wdVersion, &wdSockMsg);if (0 != nRes){cout << "网络库打开过程失败,程序即将结束!" << endl;system("pause");return 0; }

  步骤3. 检验网络库版本号

	if (2 != HIBYTE(wdSockMsg.wVersion) || 2 != LOBYTE(wdSockMsg.wVersion)){cout << "网络库版本有误,程序即将结束!" << endl;system("pause");WSACleanup();return 0;}

  步骤4. 创建服务器端SOCKET对象(便于客户端联系服务器)

	pubServerSock = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);if (INVALID_SOCKET == pubServerSock){cout << "创建服务器端SOCKET对象失败,程序即将结束!" << endl;system("pause");WSACleanup();return 0;//结束程序运行}printf("已与服务器连接...\n");

  步骤5. 链接到服务器(关于IP地址:客户端填写IP地址等也是服务器端的,注意事项参考前文

	sockaddr_in serverSockAdd;serverSockAdd.sin_family = AF_INET;serverSockAdd.sin_port = htons(12345); //端口号与服务器程序保持一致serverSockAdd.sin_addr.S_un.S_addr = inet_addr("127.0.0.1");//同上int res = connect(pubServerSock, (struct sockaddr*)&serverSockAdd, sizeof(serverSockAdd));if(SOCKET_ERROR == res){cout << "链接服务器失败,程序即将结束!" << endl;system("pause");closesocket(pubServerSock);WSACleanup();return 0;}

   步骤6. 与服务器接收、发送消息。

	thread clientThread1(clientRecv); //利用多线程类调用子程序thread clientThread2(clientSend); //利用多线程类调用子程序clientThread1.join();clientThread2.join();

  步骤7. 程序结束

	closesocket(pubServerSock);WSACleanup();system("pause");return 0;
}

  四、子程序实现
  1. 收信息子程序

void clientRecv()
{while (true){char buf[1024] = { 0 };int res = recv(pubServerSock, buf, 1024 - 1, 0);if (SOCKET_ERROR == res || 0 == res){cout << "程序运行失败或链接中断!" << endl;closesocket(pubServerSock);WSACleanup();system("pause");exit(0);}else{cout << buf << endl;}}
}

2. 发信息子程序

void clientSend()
{while (true){string buf;cin >> buf;int res = send(pubServerSock, buf.c_str(), strlen(buf.c_str()), 0);if (SOCKET_ERROR == res){cout << "程序运行失败或链接中断。。。" << endl;closesocket(pubServerSock);//		closesocket(pubClientSock);WSACleanup();system("pause");exit(0);}}
}

五、运行结果截图

这篇关于C++小程序:同一路由器下两台计算机间简单通信(2/2)——客户端的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

【C++ Primer Plus习题】13.4

大家好,这里是国中之林! ❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看← 问题: 解答: main.cpp #include <iostream>#include "port.h"int main() {Port p1;Port p2("Abc", "Bcc", 30);std::cout <<

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

hdu2289(简单二分)

虽说是简单二分,但是我还是wa死了  题意:已知圆台的体积,求高度 首先要知道圆台体积怎么求:设上下底的半径分别为r1,r2,高为h,V = PI*(r1*r1+r1*r2+r2*r2)*h/3 然后以h进行二分 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#includ

C++包装器

包装器 在 C++ 中,“包装器”通常指的是一种设计模式或编程技巧,用于封装其他代码或对象,使其更易于使用、管理或扩展。包装器的概念在编程中非常普遍,可以用于函数、类、库等多个方面。下面是几个常见的 “包装器” 类型: 1. 函数包装器 函数包装器用于封装一个或多个函数,使其接口更统一或更便于调用。例如,std::function 是一个通用的函数包装器,它可以存储任意可调用对象(函数、函数

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

06 C++Lambda表达式

lambda表达式的定义 没有显式模版形参的lambda表达式 [捕获] 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 有显式模版形参的lambda表达式 [捕获] <模版形参> 模版约束 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 含义 捕获:包含零个或者多个捕获符的逗号分隔列表 模板形参:用于泛型lambda提供个模板形参的名

usaco 1.3 Prime Cryptarithm(简单哈希表暴搜剪枝)

思路: 1. 用一个 hash[ ] 数组存放输入的数字,令 hash[ tmp ]=1 。 2. 一个自定义函数 check( ) ,检查各位是否为输入的数字。 3. 暴搜。第一行数从 100到999,第二行数从 10到99。 4. 剪枝。 代码: /*ID: who jayLANG: C++TASK: crypt1*/#include<stdio.h>bool h

uva 10387 Billiard(简单几何)

题意是一个球从矩形的中点出发,告诉你小球与矩形两条边的碰撞次数与小球回到原点的时间,求小球出发时的角度和小球的速度。 简单的几何问题,小球每与竖边碰撞一次,向右扩展一个相同的矩形;每与横边碰撞一次,向上扩展一个相同的矩形。 可以发现,扩展矩形的路径和在当前矩形中的每一段路径相同,当小球回到出发点时,一条直线的路径刚好经过最后一个扩展矩形的中心点。 最后扩展的路径和横边竖边恰好组成一个直