2、UDP服务器中,使用connect函数,实现唯一的客户端与服务器通话。

UDPserver.c

#include<myhead.h>

#define SERPORT 6660

#define SERIP "192.168.0.116"

int main(int argc, const char *argv[])

{

//1、创建套接字

int oldfd = socket(AF_INET,SOCK_DGRAM,0);//para1:ipv4,para2:udp

if(oldfd == -1)

{

perror("socket");

return -1;

}

struct sockaddr_in sin = {

.sin_family = AF_INET,

.sin_port = htons(SERPORT),

.sin_addr.s_addr =inet_addr(SERIP),

};

//2、绑定

if(bind(oldfd,(struct sockaddr *)&sin,sizeof(sin))==-1)

{

perror("绑定失败");

return -1;

}

printf("绑定success");

struct sockaddr_in cin;

socklen_t cinlen = sizeof(cin);

//3、收发消息

char buff[100];

while(1)

{

memset(buff,0,sizeof(buff));

int len =recvfrom(oldfd,buff,sizeof(buff),0,(struct sockaddr *)&cin,&cinlen);//不用管谁发的

//buff[len-1]='\0';

if(strcmp(buff,"mode")==0)

{

connect(oldfd,(struct sockaddr *)&cin,cinlen);

printf("服务器只能与一个客户端通信");

}

if(len==0)

{

perror("客户端跑了");

break;

}

printf("服务器接收到信息%s\n",buff);

// printf("服务器发消息:");

// fgets(buff,sizeof(buff),stdin);

// strcat(buff,"666");

// sendto(oldfd,buff,sizeof(buff),0,(struct sockaddr*)&cin,cinlen);

// printf("发送成功\n");

}

close(oldfd);

return 0;

}

UDPclient

#include<myhead.h>

#define SEVIP "192.168.0.116"

#define SEVPORT 6660

typedef struct sockaddr_in socketaddr;

int main(int argc, const char *argv[])

{

int oldfd=socket(AF_INET,SOCK_DGRAM,0);

if(oldfd == -1)

{

perror("socket");

return -1;

}

in_addr_t port_t = htons(SEVPORT);

in_addr_t ip_t = inet_addr(SEVIP);

socketaddr cln = {

.sin_family = AF_INET,

.sin_port = port_t,

.sin_addr.s_addr = ip_t };

int clnlen = sizeof(cln);

char buff[1024]="";

while(1)

{

printf("客户端发送给服务端:");

fgets(buff,sizeof(buff),stdin);

buff[strlen(buff)-1]='\0';

sendto(oldfd,buff,sizeof(buff),0,(struct sockaddr*)&cln,clnlen);

}

return 0;

}

相关推荐
W23035765731 小时前
经典算法:最长上升子序列(LIS)深度解析 C++ 实现
开发语言·c++·算法
2401_892070981 小时前
链栈(链式栈) 超详细实现(C 语言 + 逐行精讲)
c语言·数据结构·链栈
minji...2 小时前
Linux 线程同步与互斥(三) 生产者消费者模型,基于阻塞队列的生产者消费者模型的代码实现
linux·运维·服务器·开发语言·网络·c++·算法
语戚3 小时前
力扣 968. 监控二叉树 —— 贪心 & 树形 DP 双解法递归 + 非递归全解(Java 实现)
java·算法·leetcode·贪心算法·动态规划·力扣·
skywalker_113 小时前
力扣hot100-7(接雨水),8(无重复字符的最长子串)
算法·leetcode·职场和发展
bIo7lyA8v4 小时前
算法稳定性分析中的输入扰动建模的技术9
算法
CoderCodingNo4 小时前
【GESP】C++三级真题 luogu-B4499, [GESP202603 三级] 二进制回文串
数据结构·c++·算法
sinat_286945194 小时前
AI Coding 时代的 TDD:从理念到工程落地
人工智能·深度学习·算法·tdd
炽烈小老头4 小时前
【 每天学习一点算法 2026/04/12】x 的平方根
学习·算法