【计算机网络学习之路】Windows下的socket编程

文章目录

  • 前言
  • Windows下的socket编程
    • 1.预备工作
    • 2. socket编程
  • 结束语

前言

本系列文章是计算机网络学习的笔记,欢迎大佬们阅读,纠错,分享相关知识。希望可以与你共同进步。

本篇文章仅记录Windows下socket编程和Linux的不同,并没有讲解socket编程的原理和细节
socket编程的原理和细节可以参看【计算机网络学习之路】UDP socket编程
环境是Linux

Windows下的socket编程

1.预备工作

首先,需要添加头文件和引入库

#include<WinSock2.h>#pragma comment(lib,"ws2_32.lib")

其次,Windows下还需要先验明版本

#include <iostream>
#include <string>
#include <WinSock2.h>#pragma warning(disable:4996)//忽略次告警
#pragma comment(lib, "ws2_32.lib")int main()
{WSADATA WSADate;//初始化网络环境if(WSAStartup(MAKEWORD(2,2),&WSADate)!=0) //使用2.2版本的Socket。{std::cerr << "init error" << std::endl;return -1;}
}

WSAStartup():主要就是进行相应的socket库绑定。
使用Socket的程序在使用Socket之前必须调用WSAStartup函数。
以后应用程序就可以调用所请求的Socket库中的其它Socket函数了,然后绑定找到的Socket库到该应用程序中。该函数执行成功后返回0。

int WSAStartup ( WORD wVersionRequested, LPWSADATA lpWSAData );

WSADATA:这个结构被用来存储被WSAStartup函数调用后返回的Winsock.dll执行的数据。
MAKEWORD(2,2):使用WINSOCK2版本.wsaData用来存储系统传回的关于WINSOCK的资料

  WORD MAKEWORD( BYTE bLow, //指定新变量的低字节序; BYTE bHigh //指定新变量的高字节序; ); makeword是将两个byte型合并成一个word型,一个在高8(b),一个在低8(a) 

2. socket编程

接下来就是正常的socket编程

本篇博客举例echo客户端

套接字在Windows中有自己的结构体——SOCKET
最后关闭套接字需要使用closesocket()函数
还需要调用WSACleanup()函数

WSACleanup():用来解除与Socket库的绑定
应用程序在完成对请求的Socket库的使用后,要调用WSACleanup函数来解除与Socket库的绑定并且释放Socket库所占用的系统资源。

int WSACleanup (void);

echo客户端

#include <iostream>
#include <string>
#include <WinSock2.h>#pragma warning(disable:4996)#pragma comment(lib, "ws2_32.lib")//硬编码服务器的端口号和IP
uint16_t serverport =
std::string serverip =int main()
{WSADATA WSADate;//初始化网络环境if (WSAStartup(MAKEWORD(2, 2), &WSADate) != 0) //使用2.2版本的Socket。{std::cerr << "init error" << std::endl;return -1;}//创建套接字SOCKET sock = socket(AF_INET, SOCK_DGRAM, 0);if (sock < 0){std::cerr << "create socket error" << std::endl;exit(-2);}// 明确server是谁struct sockaddr_in server;memset(&server, 0, sizeof(server));server.sin_family = AF_INET;server.sin_port = htons(serverport);server.sin_addr.s_addr = inet_addr(serverip.c_str());//收发消息while (true){// 用户输入std::string message;std::cout << "Please Enter Your Message# ";std::getline(std::cin, message);// 发送数据sendto(sock, message.c_str(), message.size(), 0, (struct sockaddr*)&server, sizeof(server));// 接受数据char buffer[2048];struct sockaddr_in temp;int len = sizeof(temp);int n = recvfrom(sock, buffer, sizeof(buffer) - 1, 0, (struct sockaddr*)&temp, &len);if (n > 0){buffer[n] = 0;std::cout << buffer << std::endl; //1}}closesocket(sock);WSACleanup();//清理网络环境,释放socket所占的资源return 0;
}

结束语

本篇博客到此结束,感谢看到此处。
欢迎大家纠错和补充
如果觉得本篇文章对你有所帮助的话,不妨点个赞支持一下博主,拜托啦,这对我真的很重要。
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/156506.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

将docker镜像打包成tar.gz包

docker save -o web10.tar localhost:8000:1.0 生成web10.tar gzip web10.tar 生成web10.tar.gz

Vue3的响应式更新是由什么实现的

目录 而Vue3则利用了Proxy的强大特性来实现了响应式更新。 以上代码中&#xff0c;我们定义了一个原始的data对象&#xff0c;并将其使用Proxy进行了代理。在代理对象proxy中&#xff0c;我们定义了get和set两个方法&#xff0c;当我们读取或设置响应式数据的值时&#xff0c…

云ES容灾方案

一、ES集群可用性容灾 1.1 云ES集群可用性容灾(使用跨可用区实例) 云ES集群部署在三个可用区,单可用区故障,云ES集群依然可能对外提供服务;两个可用区故障,需要进行控制台切流(集群会自动切的选择主节点) 应用服务部署在二个可用区,单可用区故障,依然可对提供服务1.2 …

开源网安解决方案荣获四川数实融合创新实践优秀案例

​11月16日&#xff0c;2023天府数字经济峰会在成都圆满举行。本次峰会由四川省发展和改革委员会、中共四川省委网络安全和信息化委员会办公室、四川省经济和信息化厅等部门联合指导&#xff0c;聚焦数字经济与实体经济深度融合、数字赋能经济社会转型发展等话题展开交流研讨。…

vue2【相关介绍】

目录 1&#xff1a;什么是单页面应用程序 2&#xff1a;什么是vue-cli 3&#xff1a;安装使用 4&#xff1a;vue项目的目录结构&#xff1a;​编辑 5&#xff1a;了解src目录的构成&#xff1a; 6&#xff1a;vue项目的运行流程 7&#xff1a;el&#xff1a;容器名称&…

python paramiko模块

示例 import paramikossh paramiko.SSHClient() ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) # 自动添加主机名及主机密钥到本地 HostKeys 对象&#xff0c;默认是拒绝未知的 ssh 服务器连接 ssh.connect(node, usernameyour_username, passwordyour_passwo…

ChatGPT暂时停止开通plus,可能迎来封号高峰期

前言: 前两日,chat gpt的创始人 San Altman在网上发表了,由于注册的使用量超过了他们的承受能力,为了确保每个人的良好使用体验,chat gpt将暂时停止开通gpt plus。 情况: 前段时间好像出现了官网崩溃的情况,就连api key都受到了影响,所以现在就开始了暂时停止plus的注…

leetcode做题笔记2216. 美化数组的最少删除数

给你一个下标从 0 开始的整数数组 nums &#xff0c;如果满足下述条件&#xff0c;则认为数组 nums 是一个 美丽数组 &#xff1a; nums.length 为偶数对所有满足 i % 2 0 的下标 i &#xff0c;nums[i] ! nums[i 1] 均成立 注意&#xff0c;空数组同样认为是美丽数组。 你…

本机idea连接虚拟机中的Hbase

相关环境&#xff1a; 虚拟机&#xff1a;Centos7 hadoop版本:3.1.3 hbase版本:2.4.11 zookeeper版本:3.5.7 Java IDE:IDEA JDK&#xff1a;8 步骤 步骤一&#xff1a;在idea创建一个maven项目 步骤二&#xff1a;在虚拟机里找到core-site.x…

Epoll:让IO多路复用变得有趣

Epoll 是 Linux 系统中高性能的 I/O 事件通知机制&#xff0c;通过它可以实现对大量文件描述符的高效监控&#xff0c;适用于构建高并发的网络服务器。 文章目录 epoll介绍主要特点epoll与poll、select区别效率和扩展性文件描述符数量限制工作模式小结 epoll常用函数epoll_crea…

苹果ipa内侧分发可以通过哪些方法

苹果ipa内侧分发可以通过使用苹果企业签名、云服务分发平台、TestFlight分发等方式实现。 对于企业签名&#xff0c;它适合用于公司内部员工使用的应用&#xff0c;或者需要快速安装和使用的应用。开发者可以在苹果开发者中心生成企业级证书&#xff0c;然后将应用打包成IPA文…

如何在3dMax中使用Python返回场景内所有对象的列表?

如何在3dMax中使用Python返回场景内所有对象的列表&#xff1f; 3dMax支持开发基于Python的工具和扩展&#xff0c;因此可以对其进行自定义并将其集成到现代数字内容创建管道中。为此&#xff0c;3dMax集成了Python 3.9解释器&#xff0c;并通过pymxs API公开了3dMax的丰富功能…

如何有效的禁止Google Chrome自动更新?

禁止Chrome自动更新 1、背景2、操作步骤 1、背景 众所周知&#xff0c;当我们在使用Selenium进行Web自动化操作&#xff08;如爬虫&#xff09;时&#xff0c;一般会用到ChromeDriver。然而Driver的更新速度明显跟不上Chrome的自动更新。导致我们在使用Selenium进行一些操作时就…

工业交换机的六种分类

工业交换机可以按照不同的标准进行分类&#xff0c;具体有六种分类方法。我们今天就来简单了解一下这六种分类方法&#xff0c;它们分别是&#xff1a;工业交换机的管理标准、工业交换机的结构标准、工业交换机的网络位置、工业交换机的传输速率、工业交换机的工作协议以及工业…

[软件安装]anaconda安装

anaconda安装 以下是在Linux下安装anaconda的详细步骤&#xff1a; 首先&#xff0c;在anaconda官网上下载适用于Linux的anaconda安装包。 打开终端&#xff0c;进入下载目录并解压安装包。 执行以下命令进入安装程序&#xff1a;bash Anaconda3-2021.05-Linux-x86_64.sh …

提升--09-1--AQS底层逻辑实现

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 一、怎么解释AQS是什么&#xff1f;AQS的本质是JUC包下一个抽象类&#xff0c;AbstractQueuedSynchronizer &#xff08;抽象的队列式同步器&#xff09; 二、AQS核…

四川芸鹰蓬飞:抖店运营的时候注意什么?

抖店作为一个短视频平台&#xff0c;吸引了越来越多的商家加入。在抖店上进行有效的运营是提高销量和曝光度的关键。那么&#xff0c;抖店怎么设置运营呢&#xff1f;有哪些方法可以帮助商家在这个竞争激烈的平台上脱颖而出呢&#xff1f; 一、抖店怎么设置运营&#xff1f; 首…

三点的最近距离

题目描述 题目中会给你三个整数 a,b,c,表示三个点在数轴上所处的位置。对于每一个点&#xff0c;你最多可以移动一次&#xff0c;也可以选择不移动&#xff0c;现在请你编写代码计算&#xff0c;移动后三个点的最小的距离和为多少&#xff1f; 输入输出格式 输入格式 一行三…

微服务实战系列之加密RSA

前言 在这个时代&#xff0c;我们选择的人生目标已丰富多彩&#xff0c;秉持的人生态度也千差万别&#xff1a; 除了吃喝玩乐&#xff0c;还有科技探索&#xff1b; 除了CityWalk&#xff0c;还有“BookWalk”&#xff1b; 除了走遍中国&#xff0c;还有走遍世界&#xff1b; …

118. 杨辉三角 --力扣 --JAVA

题目 给定一个非负整数 numRows&#xff0c;生成「杨辉三角」的前 numRows 行。 在「杨辉三角」中&#xff0c;每个数是它左上方和右上方的数的和。 解题思路 List的首位是0&#xff0c;而行数的首位是1&#xff0c;所以我们在进行行数循环时需要小于numRows&#xff0c;而在统…