Windows TCP 通信测试_1

一、单对单通信测试

应用函数 socket、bind、connect、listen、accept、recv、send(win下的函数)等

1、客户端demo client.cpp

#include<WINSOCK2.H>
#include<STDIO.H>
#include<iostream>
#include<cstring>
using namespace std;
#pragma comment(lib, "ws2_32.lib")
#define CONNECT_COUNT_MAX  20
#define CONNECT_INTERVAL_MS 1000
int main()
{WORD sockVersion = MAKEWORD(2, 2);WSADATA data;if(WSAStartup(sockVersion, &data)!=0){return 0;}
while(true){SOCKET sclient = socket(AF_INET, SOCK_STREAM, 0);//IPPROTO_TCPif(sclient == INVALID_SOCKET){printf("invalid socket!");WSACleanup();system("pause");return 0;}// 设定客户端协议族、端口、ip信息sockaddr_in clientAddr;clientAddr.sin_family = AF_INET;clientAddr.sin_port = htons(8888);clientAddr.sin_addr.S_un.S_addr = inet_addr("127.6.6.2");if (bind(sclient,(struct sockaddr *)&clientAddr,sizeof(clientAddr))==0){    //client信息绑定到clientfd上printf("client socket bind success\n");}; // 设定服务端协议族、端口、ip信息sockaddr_in serAddr;serAddr.sin_family = AF_INET;serAddr.sin_port = htons(9999);serAddr.sin_addr.S_un.S_addr = inet_addr("127.6.6.254");// while(true){int connect_flag_ = 0; //TCP connect 结果标志位int connect_count_ = 0; //TCP connect 重试次数while(connect_count_ <  CONNECT_COUNT_MAX){connect_flag_ = connect(sclient, (sockaddr *)&serAddr, sizeof(serAddr));if(connect_flag_ == SOCKET_ERROR){  //连接失败 printf("connect error, retry time: [%d]!\n", connect_count_);connect_count_ ++;Sleep(CONNECT_INTERVAL_MS); //休眠一段时间再重试connect}else{printf("connect success, retry time: [%d]!\n", connect_count_);break;}}if(connect_count_ == CONNECT_COUNT_MAX){      //达到了最大connect次数,结束printf("connect error ,retry finshed!\n");closesocket(sclient);WSACleanup();system("pause");return 0;}string client_id = "[client_1] : ";bool input_flag_ = false;   //选择传入手动输入消息还是默认消息// string data;const char * sendData;int client_send_flag_ = 0;if(input_flag_){char data[128] = {};cin >> data;sendData = (client_id + data).c_str();   //string转const char*cout << "client msg : " << sendData << endl;client_send_flag_ = send(sclient, sendData, strlen(sendData), 0);}else{char *sendData = "我是北方的狼";cout << "client msg : " << sendData << endl;client_send_flag_ = send(sclient, sendData, strlen(sendData), 0);Sleep(3000);};//send()用来将数据由指定的socket传给对方主机/*int send(int s, const void * msg, int len, unsigned int flags)s为已建立好连接的socket,msg指向数据内容,len则为数据长度,参数flags一般设0成功则返回实际传送出去的字符数,失败返回-1,错误原因存于error */if(client_send_flag_ >= 0){   //send 失败或成功提示printf(" send msg success!\n");}else{printf(" send msg fail!!\n");}char recData[255];int ret = recv(sclient, recData, 255, 0);/*  函数原型:int recv( SOCKET s, char *buf, int len, int flags) 功能: 用recv函数从TCP连接的另一端接收数据。 参数一:指定接收端套接字描述符; 参数二:指明一个缓冲区,该缓冲区用来存放recv函数接收到的数据; 参数三:指明buf的长度; 参数四 :一般置为0。 返回值 : 读出来的字节大小*/if(ret>0){recData[ret] = 0x00;printf(recData);} closesocket(sclient);}// }WSACleanup();return 0;}

特点

1、轮询重试

2、测试时可先于服务端启动

3、发送消息可以选择周期发或者手动输入;(bug:目前手动输入过长字符会有发送异常的情况出现)

2、服务端demo server.cpp

#include <stdio.h>  
#include <winsock2.h>  
#include<iostream>
#include<cstring>
#include<Windows.h>
#include<future>// #include<promise>#pragma comment(lib,"ws2_32.lib")  #define DATA_SIZE 1024
using namespace std;
#if 0
future_status getRecvResult(SOCKET sClientfd, char *revData , int* ret){std::future<int> ret1 = std::async(std::launch::async, recv , sClientfd, revData, DATA_SIZE, 0); //异步调用std::future_status sts = ret1.wait_for(std::chrono::seconds(1)); //设置超时时间 s'*ret = ret1.get();return sts;
}
#endif
int main(int argc, char* argv[])  
{  //初始化WSA  WORD sockVersion = MAKEWORD(2,2);  WSADATA wsaData;  if(WSAStartup(sockVersion, &wsaData)!=0)  {  return 0;  }  //创建套接字  SOCKET slisten = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);  if(slisten == INVALID_SOCKET)  {  printf("socket error !");  return 0;  }  //绑定IP和端口  sockaddr_in serveraddr;  serveraddr.sin_family = AF_INET;  serveraddr.sin_port = htons(9999);  // serveraddr.sin_addr.S_un.S_addr = INADDR_ANY;   //可以是系统端口 serveraddr.sin_addr.S_un.S_addr = inet_addr("127.6.6.254");if(bind(slisten, (LPSOCKADDR)&serveraddr, sizeof(serveraddr)) == SOCKET_ERROR)  {  printf("bind error !");  }  //开始监听  if(listen(slisten, 5) == SOCKET_ERROR){  printf("listen error !");  return 0;  }  //循环接收数据  SOCKET sClientfd;  sockaddr_in remoteAddr;  int nAddrlen = sizeof(remoteAddr);  while (true)  {  printf("等待连接...\n");  sClientfd = accept(slisten, (SOCKADDR *)&remoteAddr, &nAddrlen);/*listen监听客户端来的链接,accept将客户端的信息绑定到一个socket上,也就是给客户端创建一个socket,通过返回值返回给我们客户端的socket。accept函数的第一个参数为服务器的socket描述字,第二个参数为指向struct sockaddr *的指针,用于返回客户端的协议地址,第三个参数为协议地址的长度。如果accpet成功,那么其返回值是由内核自动生成的一个全新的描述字,代表与返回客户的TCP连接。成功:返回值就是给客户端包好的socket; 与客户端通信就靠这个失败:返回INVALIE_SOCKET; 通过WSAGetLastError()得到错误码*/// while (true)  // {    if(sClientfd <= 0 )  {  printf("accept error !");cout << WSAGetLastError() << endl;Sleep(2000);  continue;  }  printf("接受到一个连接:%s \r\n", inet_ntoa(remoteAddr.sin_addr));  //接收数据 // char revData[2] = {}; // int data_size = sizeof(revData);string tmp = "";int ret = 0;do    //怕数据太长,一次recv copy不完,为了把client端一次发的的消息拼接、打印{char revData[DATA_SIZE] = {}; revData[DATA_SIZE] = 0x00;   // 抵消数组后面的字符cout << "start " << revData <<endl;/*  // 下面的异步超时操作是为了把client端一次发的的消息拼接、打印(主要是一条消息最后一次数据大小 = DATA_SIZE的情况);;不过有bug,没想好怎么解决std::future<int> ret1 = std::async(std::launch::async, recv , sClientfd, revData, DATA_SIZE, 0); //异步调用std::future_status sts = ret1.wait_for(std::chrono::seconds(1)); //设置超时时间 s'if(sts == std::future_status::ready){// ret = ret1.get();printf("超时时间内收到了回复\n");}else if(sts == std::future_status::timeout){printf("设定时间内无消息\n");ret = 0;break;      }*/ret = recv(sClientfd, revData, DATA_SIZE, 0);  // 在主线程操作,如果recv大小正好是个整数包,一直阻塞在这,不会给该client返回消息;//这是上面do while想做的事情可能带来的影响cout << "server ret = " << ret << endl;if(ret <= 0){printf("receive msg error\n");// system("pause");Sleep(3000);break;}if(ret  < DATA_SIZE){revData[ret] = 0x00;cout << "last phase " << revData <<endl;}tmp = tmp + revData;cout << "tmp :[" << tmp << "] , leave"<<endl;} while (ret  == DATA_SIZE);cout <<'['<< tmp << ']'<<endl;//发送数据  const char * sendData = "你好,TCP客户端!\n";  send(sClientfd, sendData, strlen(sendData), 0);  closesocket(sClientfd);Sleep(1000);}  closesocket(slisten);  WSACleanup();  return 0;  
} 

特点

1、为了一次打印client发送的消息,做了一点愚蠢的特殊处理。。。

2、没有做超时,socket没有消息会一直阻塞;

3、验证

编译:

g++ server.cpp -o server -lwsock32

g++ client.cpp -o client -lwsock32  

二、多个客户端通信测试(有bug)

新增加select的使用

1、客户端新增demo client_2.cpp

#include<WINSOCK2.H>
#include<STDIO.H>
#include<iostream>
#include<cstring>
using namespace std;
#pragma comment(lib, "ws2_32.lib")
#define CONNECT_COUNT_MAX  20
#define CONNECT_INTERVAL_MS 1000
#define INPUT_FLAG   true
int main()
{WORD sockVersion = MAKEWORD(2, 2);WSADATA data;if(WSAStartup(sockVersion, &data)!=0){return 0;}
while(true){SOCKET sclient = socket(AF_INET, SOCK_STREAM, 0);//IPPROTO_TCPif(sclient == INVALID_SOCKET){printf("invalid socket!");WSACleanup();system("pause");return 0;}// 设定客户端协议族、端口、ip信息sockaddr_in clientAddr;clientAddr.sin_family = AF_INET;clientAddr.sin_port = htons(8888);clientAddr.sin_addr.S_un.S_addr = inet_addr("127.6.6.4");if (bind(sclient,(struct sockaddr *)&clientAddr,sizeof(clientAddr))==0){    //client信息绑定到clientfd上printf("client socket bind success\n");}; // 设定服务端协议族、端口、ip信息sockaddr_in serAddr;serAddr.sin_family = AF_INET;serAddr.sin_port = htons(9999);serAddr.sin_addr.S_un.S_addr = inet_addr("127.6.6.254");// while(true){int connect_flag_ = 0; //TCP connect 结果标志位int connect_count_ = 0; //TCP connect 重试次数while(connect_count_ <  CONNECT_COUNT_MAX){connect_flag_ = connect(sclient, (sockaddr *)&serAddr, sizeof(serAddr));if(connect_flag_ == SOCKET_ERROR){  //连接失败 printf("connect error, retry time: [%d]!\n", connect_count_);connect_count_ ++;Sleep(CONNECT_INTERVAL_MS); //休眠一段时间再重试connect}else{printf("connect success, retry time: [%d]!\n", connect_count_);break;}}if(connect_count_ == CONNECT_COUNT_MAX){      //达到了最大connect次数,结束printf("connect error ,retry finshed!\n");closesocket(sclient);WSACleanup();system("pause");return 0;}string client_id = "[client_1] : ";bool input_flag_ = INPUT_FLAG;   //选择传入手动输入消息还是默认消息// string data;const char * sendData;int client_send_flag_ = 0;if(input_flag_){char data[128] = {};cin >> data;sendData = (client_id + data).c_str();   //string转const char*cout << "client msg : " << sendData << endl;client_send_flag_ = send(sclient, sendData, strlen(sendData), 0);}else{char *sendData = "我是北方的羊";cout << "client msg : " << sendData << endl;client_send_flag_ = send(sclient, sendData, strlen(sendData), 0);Sleep(3000);};//send()用来将数据由指定的socket传给对方主机/*int send(int s, const void * msg, int len, unsigned int flags)s为已建立好连接的socket,msg指向数据内容,len则为数据长度,参数flags一般设0成功则返回实际传送出去的字符数,失败返回-1,错误原因存于error */if(client_send_flag_ >= 0){   //send 失败或成功提示printf(" send msg success!\n");}else{printf(" send msg fail!!\n");}char recData[255];int ret = recv(sclient, recData, 255, 0);/*  函数原型:int recv( SOCKET s, char *buf, int len, int flags) 功能: 用recv函数从TCP连接的另一端接收数据。 参数一:指定接收端套接字描述符; 参数二:指明一个缓冲区,该缓冲区用来存放recv函数接收到的数据; 参数三:指明buf的长度; 参数四 :一般置为0。 返回值 : 读出来的字节大小*/if(ret>0){recData[ret] = 0x00;printf(recData);} closesocket(sclient);}// }WSACleanup();return 0;}

2、服务端demo server_select.cpp

#include <stdio.h>  
#include <winsock2.h>  
#include<iostream>
#include<cstring>
#include<Windows.h>
#include<future>// #include<promise>#pragma comment(lib,"ws2_32.lib")  #define DATA_SIZE 1024
using namespace std;
#if 0
future_status getRecvResult(SOCKET sClientfd, char *revData , int* ret){std::future<int> ret1 = std::async(std::launch::async, recv , sClientfd, revData, DATA_SIZE, 0); //异步调用std::future_status sts = ret1.wait_for(std::chrono::seconds(1)); //设置超时时间 s'*ret = ret1.get();return sts;
}
#endif
int main(int argc, char* argv[])  
{  //初始化WSA  WORD sockVersion = MAKEWORD(2,2);  WSADATA wsaData;  if(WSAStartup(sockVersion, &wsaData)!=0)  {  return 0;  }  //创建套接字  SOCKET slisten = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);  if(slisten == INVALID_SOCKET)  {  printf("socket error !");  return 0;  }  //绑定IP和端口  sockaddr_in serveraddr;  serveraddr.sin_family = AF_INET;  serveraddr.sin_port = htons(9999);  // serveraddr.sin_addr.S_un.S_addr = INADDR_ANY;   //可以是系统端口 serveraddr.sin_addr.S_un.S_addr = inet_addr("127.6.6.254");if(bind(slisten, (LPSOCKADDR)&serveraddr, sizeof(serveraddr)) == SOCKET_ERROR)  {  printf("bind error !");  }  //开始监听  if(listen(slisten, 5) == SOCKET_ERROR)  {  printf("listen error !");  return 0;  }  //循环接收数据  SOCKET sClientfd;  sockaddr_in remoteAddr;  int nAddrlen = sizeof(remoteAddr);  // select 相关设置fd_set rfds, readset, wfds, writeset;SOCKET Clientfd[1024]; int maxfd = slisten; FD_ZERO(&rfds);FD_ZERO(&wfds);FD_SET(slisten, &rfds);while (true)  {printf("等待连接...\n");int selectRet = select(maxfd+1,&rfds,NULL,NULL,NULL);//select()调用返回处于就绪状态并且已经包含在fd_set结构中的描述字总数;如果超时则返回0;//否则的话,返回SOCKET_ERROR错误,应用程序可通过WSAGetLastError获取相应错误代码。if(selectRet <= 0){printf("select error [%d]\n", selectRet);       // >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>Sleep(3000);// continue;}cout << "selectRet = " << selectRet << endl;cout << "maxfd = " << maxfd << endl;cout << "slisten = " << slisten << endl;for (int fd = 0; fd <= maxfd; fd++){if(FD_ISSET(fd,&rfds)){if(fd == slisten){sClientfd = accept(slisten, (SOCKADDR *)&remoteAddr, &nAddrlen);  //如果监听的socket有消息,就接受client的socketFD_SET(sClientfd, &rfds);maxfd = sClientfd > maxfd ? sClientfd : maxfd;      // 更新maxfdbreak;}else{break;}}else{// cout << "fd = " << fd << endl;}}// if(FD_ISSET(slisten,&rfds)){//     sClientfd = accept(slisten, (SOCKADDR *)&remoteAddr, &nAddrlen);// }/*listen监听客户端来的链接,accept将客户端的信息绑定到一个socket上,也就是给客户端创建一个socket,通过返回值返回给我们客户端的socket。accept函数的第一个参数为服务器的socket描述字,第二个参数为指向struct sockaddr *的指针,用于返回客户端的协议地址,第三个参数为协议地址的长度。如果accpet成功,那么其返回值是由内核自动生成的一个全新的描述字,代表与返回客户的TCP连接。成功:返回值就是给客户端包好的socket; 与客户端通信就靠这个失败:返回INVALIE_SOCKET; 通过WSAGetLastError()得到错误码*/// while (true)  // {    if(sClientfd <= 0 )  {  printf("accept error !");cout << WSAGetLastError() << endl;Sleep(2000);  continue;  }  printf("接受到一个连接:%s \r\n", inet_ntoa(remoteAddr.sin_addr));  //接收数据 // char revData[2] = {}; // int data_size = sizeof(revData);string tmp = "";int ret = 0;do    //怕数据太长,一次recv copy不完,为了把client端一次发的的消息拼接、打印{char revData[DATA_SIZE] = {}; revData[DATA_SIZE] = 0x00;   // 抵消数组后面的字符cout << "start " << revData <<endl;/*  // 下面的异步超时操作是为了把client端一次发的的消息拼接、打印(主要是一条消息最后一次数据大小 = DATA_SIZE的情况);;不过有bug,没想好怎么解决std::future<int> ret1 = std::async(std::launch::async, recv , sClientfd, revData, DATA_SIZE, 0); //异步调用std::future_status sts = ret1.wait_for(std::chrono::seconds(1)); //设置超时时间 s'if(sts == std::future_status::ready){// ret = ret1.get();printf("超时时间内收到了回复\n");}else if(sts == std::future_status::timeout){printf("设定时间内无消息\n");ret = 0;break;      }*/ret = recv(sClientfd, revData, DATA_SIZE, 0);  // 在主线程操作,如果recv大小正好是个整数包,一直阻塞在这,不会给该client返回消息;//这是上面do while想做的事情可能带来的影响cout << "server ret = " << ret << endl;if(ret <= 0){printf("receive msg error\n");// system("pause");Sleep(3000);break;}if(ret  < DATA_SIZE){revData[ret] = 0x00;cout << "last phase " << revData <<endl;}tmp = tmp + revData;cout << "tmp :[" << tmp << "] , leave"<<endl;} while (ret  == DATA_SIZE);cout <<'['<< tmp << ']'<<endl;//发送数据  const char * sendData = "你好,TCP客户端!\n";  send(sClientfd, sendData, strlen(sendData), 0);  closesocket(sClientfd);Sleep(1000);}  closesocket(slisten);  WSACleanup();  return 0;  
} 

特点

目前也没超时,不能很好的处理多个客户端的互相影响 

3、验证

编译执行,用到上面所有的client

手动输入的client会把服务端的进程阻塞住,导致另一个client的消息也进不来,手动输入消息后,会暂时解除当前阻塞,问题不小,小白太难了,后面再搞

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

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

相关文章

nodejs+vue+python+PHP+微信小程序-婚纱摄影预约系统的设计与实现-安卓-计算机毕业设计

本婚纱摄影预约系统主要包括个人中心、套系风格管理、用户管理、摄影师管理、婚纱套系管理、婚纱套系订单管理、客片欣赏管理、客户样片管理、摄影咨询管理、客户选片管理、系统管理等多个模块。它帮助婚纱摄影预约实现了信息化、网络化&#xff0c;通过测试&#xff0c;实现了…

Python模块的导入

一、模块的定义 模块就是一个Python代码文件&#xff0c;内含类、函数、变量等&#xff0c;我们可以导入 二、如何导入模块 [from 模块名] import [ 模块 | 类 | 变量 | 函数 | *] [as 别名] 示例 1.使用import导入time模块使用sleep功能&#xff08;函数&#xff0…

基于jmeter的性能全流程测试

做性能测试的步骤 1、服务器性能监控 首先要在对应服务器上面安装性能监控工具&#xff0c;比如linux系统下的服务器&#xff0c;可以选择nmon或者其他的监控工具&#xff0c;然后在jmeter模拟场景跑脚本的时候&#xff0c;同时启动监控工具&#xff0c;这样就可以获得jmeter…

2311skia,06编解码图像上

1,API和自注册机制 Skia中只需要一行代码就可编解码图片: SkBitmap bitmap; SkImageDecoder::DecodeFile("test.xxx", &bitmap);//按文件名解码,自动推导图片类型//或按流解码 SkFILEStream stream("test.xxx"); SkImageDecoder::DecodeStream(strea…

Android之高级UI

系统ViewGroup原理解析 常见的布局容器: FrameLayout, LinearLayout,RelativeLayoout,GridLayout 后起之秀&#xff1a;ConstraintLayout,CoordinateLayout Linearlayout Overrideprotected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {if (mOrientation …

STK Components 二次开发-地面站传感器

上一篇我们说了创建地面站&#xff0c;那么这次我们在地面站添加一些特效。 1. 创建地面站 var locationPoint1 new PointCartographic(m_earth, new Cartographic(Trig.DegreesToRadians(117.17066), Trig.DegreesToRadians(31.84056), 240.359)); m_facility new Platfor…

【论文解读】Real-ESRGAN:使用纯合成数据训练真实世界的超分辨率图像

图一是4种超分方法的对比效果 。 0 摘要 尽管在盲超分辨率方面已经进行了许多尝试&#xff0c;以恢复具有未知和复杂退化的低分辨率图像&#xff0c;但它们仍然远远不能解决一般的真实世界退化图像。在这项工作中&#xff0c;我们将强大的 ESRGAN 扩展到一个实际的恢复应用程序…

Retrofit怎么返回一个JSON字符串?

项目用已经使用了 Retrofit&#xff0c;定义了接口方法&#xff0c;返回了 JSON 转换后的实体对象&#xff0c;炒鸡方便。但是总有意料之外的时候&#xff0c;比如我不需要返回实体对象&#xff0c;我要返回纯纯的 JSON 字符串&#xff0c;怎么办呢&#xff1f; 先看源码 通过…

什么是半监督学习

1 概述 1.1 定义 半监督学习&#xff08;Semi-Supervised Learning&#xff09;是机器学习中的一个重要分支&#xff0c;它介于监督学习和无监督学习之间。半监督学习利用少量标注数据和大量未标注数据共同训练模型&#xff0c;旨在充分挖掘未标注数据中潜在的信息和模式&…

git stash命令详解

git stash 工作区和暂存区的内容是公共的&#xff0c;不属于任何一个分支 所以在切换分支的时候务必保证工作区是干净的&#xff0c;否则切换过去的时候会导致那个分支也被修改了 如果不想add和commit&#xff0c;那可以用git stash将工作现场暂存一下 需要注意的是&#x…

【数据库】缓冲区管理器结构,几种常用替换策略分析,pin钉住缓冲区块防止错误的替换,以及缓冲区管理带来的代价优化

缓冲区管理 ​专栏内容&#xff1a; 手写数据库toadb 本专栏主要介绍如何从零开发&#xff0c;开发的步骤&#xff0c;以及开发过程中的涉及的原理&#xff0c;遇到的问题等&#xff0c;让大家能跟上并且可以一起开发&#xff0c;让每个需要的人成为参与者。 本专栏会定期更新&…

【算法】装备合成(二分)

链接&#xff1a;登录—专业IT笔试面试备考平台_牛客网 来源&#xff1a;牛客网 题目描述 牛牛有x件材料a和y件材料b&#xff0c;用2件材料a和3件材料b可以合成一件装备&#xff0c;用4件材料a和1件材料b也可以合成一件装备。牛牛想要最大化合成的装备的数量&#xff0c;于是…

重新开启GPT Plus充值通道——基于前端开发者工具

chatGPT PLUS充值通道的关闭 由于chatGPT用户激增&#xff0c;近日&#xff0c;OpenAI的CEO Sam Altman宣布需要暂停新用户对ChatGPT Plus的订阅。在X上&#xff0c;他表达了对于确保用户体验的承诺&#xff0c;同时也提到了用户可以通过应用程序内的通知功能来了解服务恢复的…

代码随想录算法训练营 ---第四十五天

前言&#xff1a; 昨天的题做过之后&#xff0c;今天的题基本上都很简单&#xff0c;但是要注重一下细节。 第一题&#xff1a; 简介&#xff1a; 动态规划五部曲&#xff1a; 1.确定dp数组的含义 dp[i]&#xff1a;爬到有i个台阶的楼顶&#xff0c;有dp[i]种方法 2.确定dp…

常见指令的数据通路和执行过程

作此篇的原因是17年19题&#xff1a; 本题选A&#xff0c;做的时候总感觉不够通透&#xff0c;因此把这题涉及到的内容全部看了一遍&#xff0c;顿时没有那种朦胧感了 零、五段式流水线&#xff1a; 以下均为MIPS设定&#xff1a;指令长度为32位&#xff0c;主存按字节编址&a…

gpt是如何进行训练的?

原理 gpt就是一个类似于成语接龙的游戏&#xff0c;根据之前的n个字符&#xff0c;预测下一个字符&#xff0c;那么gpt的输入和输出是如何构造的呢&#xff1f;比如给一个句子如下&#xff1a; sentence&#xff1a;如何理解gpt的原理。 构造gpt输入输入&#xff1a; input&am…

Echarts 最简单创建柱状图

设置容器 <div ref"myChart" style"width: 500px; height: 500px;"> </div>mounted() {//document渲染完成this.draw()}draw() {const myChart this.$echarts.init(this.$refs.myChart)//初始化对象myChart.setOption({ //参数配置项title: …

探索接口测试:SOAP、RestFul规则、JMeter及市面上的接口测试工具

引言 在当今软件开发领域&#xff0c;接口测试扮演着至关重要的角色。随着系统变得日益复杂和互联&#xff0c;对于内部和外部接口的测试变得愈发关键。接口测试不仅仅是验证接口的正确性&#xff0c;更是确保系统的稳定性、安全性和性能优越性的关键一环。 本篇博客将带您深入…

自动化任务:探索 Shell 脚本的实际应用

引言 在前一篇文章中&#xff0c;我们学习了 Shell 脚本的基础知识和语法。现在&#xff0c;让我们深入探讨 Shell 脚本在自动化任务中的实际应用。Shell 脚本能够帮助我们批量处理文件、定时执行任务等&#xff0c;提高工作效率。 批量处理文件 场景介绍&#xff1a; 假设我…

一次简单的 Http 请求异常处理 (请求的 url 太长, Nginx 直接返回 400, 导致请求服务异常)

1 结论 按照惯例直接说结论。 后台服务 A 有一个 Http 接口, 代码如下: RequestMapping(value "/user", method RequestMethod.GET) public List<UserInfoVo> getUserInfoByUserIds(RequestParam(value "userIds") List<String> userIds…