Linux--UDP编程

news/2024/5/18 15:14:12 标签: udp, 网络协议, 网络

目录

一、实现的过程

二、代码:

1.ser.c

2.cli.c

三、运行结果

 四、服务器端断开重运行,客户端还能发送吗?(可以)

五、可以同时运行两个客户端吗?(可以) 

六、数据读取 

//不粘包,会丢包


一、实现的过程

 //无连接、不可靠、尽最大的努力发出去,不保证能收到,效率高

UDP:视频传输,eg:打视频电话,处理丢包的成本很低;

二、代码:

1.ser.c

#include<stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <assert.h>
#include <sys/socket.h>
#include <string.h>
#include <netinet/in.h>
#include <arpa/inet.h>

int main()
{
    int sockfd=socket(AF_INET,SOCK_DGRAM,0);
    if(sockfd==-1)
    {   
        exit(0);
    }   

    struct sockaddr_in saddr,caddr;
    memset(&saddr,0,sizeof(saddr));
    saddr.sin_family=AF_INET;
    saddr.sin_port=htons(6000);
    saddr.sin_addr.s_addr=inet_addr("127.0.0.1");

    int res=bind(sockfd,(struct sockaddr*)&saddr,sizeof(saddr));

    while(1)
    {   
        int len=sizeof(caddr);
        char buff[128]={0};
        int n=recvfrom(sockfd,buff,127,0,(struct sockaddr*)&caddr,&len);
        printf("ip:%s,buff=%s\n",inet_ntoa(caddr.sin_addr),buff);
        sendto(sockfd,"ok",2,0,(struct sockaddr*)&caddr,sizeof(caddr));
    }   
}

2.cli.c

#include<stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <assert.h>
#include <sys/socket.h>
#include <string.h>
#include <netinet/in.h>
#include <arpa/inet.h>

int main()
{
    int sockfd=socket(AF_INET,SOCK_DGRAM,0);
    if(sockfd==-1)
    {
        exit(0);
    }

    struct sockaddr_in saddr,caddr;
    memset(&saddr,0,sizeof(saddr));
    saddr.sin_family=AF_INET;
    saddr.sin_port=htons(6000);
    saddr.sin_addr.s_addr=inet_addr("127.0.0.1");

    int res=bind(sockfd,(struct sockaddr*)&saddr,sizeof(saddr));

    while(1)
    {
        int len=sizeof(caddr);
        char buff[128]={0};
        int n=recvfrom(sockfd,buff,127,0,(struct sockaddr*)&caddr,&len);
        printf("ip:%s,buff=%s\n",inet_ntoa(caddr.sin_addr),buff);
        sendto(sockfd,"ok",2,0,(struct sockaddr*)&caddr,sizeof(caddr));
    }
}

三、运行结果

 四、服务器端断开重运行,客户端还能发送吗?(可以)

udp是无连接的,服务器端断开,客户端并不知道,只看端口,哪怕不运行,也发出去了,是不过数据丢失

五、可以同时运行两个客户端吗?(可以) 

无连接,只要有人发,就会接收,可以直接接受来自于很多客户端的数据

六、数据读取 

sendto:不能保证目的地址一样,

如果没有把数据报内容收完,那么其余数据丢失,

再次接受的时候是下一个数据报

第一次发送的数据包是一个独立个体,接受完就结束,没接收完,剩下的也丢了

//不粘包,会丢包

 将接收大小由127改成1,一次只接受一个


http://www.niftyadmin.cn/n/181400.html

相关文章

jar加密后当作SDK给别人使用(可maven引入)

1、不加密jar&#xff0c;进行提取公共代码&#xff0c;打成jar包&#xff0c;并用maven引入 参考文章&#xff1a;以maven添加依赖的方式导入自己写的项目。springboot 提取公共类&#xff0c;多服务共用 2、加密jar&#xff0c;使用ClassFinal进行jar的加密 官网地址:Clas…

智能 AI 代码生成工具 Cursor用智能生成demo:python画一棵樱花树

https://www.cursor.so/ https://openai.com/blog/chatgpt python画一棵樱花树 import turtle import randomdef tree(branchLen, t):if branchLen > 5:angle random.randint(20, 30)factor random.uniform(0.6, 0.8)t.pensize(branchLen / 10)t.forward(branchLen)t.r…

Linux C 判断一个进程是否是脚本进程

文章目录一、Linux 下常用的脚本1.1 Bash shell1.2 POSIX shell script1.3 Python script1.4 Perl script1.5 Ruby script1.6 Lua script二、脚本进程判断总结一、Linux 下常用的脚本 在 /usr/bin/ 下查看系统有哪些脚本文件。在 Linux 系统中&#xff0c;/usr/bin/ 目录下的文…

【目标检测算法实现之yolov8】yolov8训练并测试VisDrone数据集

目录1.环境准备创建yolov8虚拟环境进入虚拟环境安装pytorch v1.11.0下载yolov8的代码其他配置2.VisDrone数据集准备数据集下载数据集处理修改数据配置文件3.训练/验证/导出训练验证导出1.环境准备 在这之前&#xff0c;需要先准备主机的环境&#xff0c;环境如下&#xff1a; …

Federation HDFS VS HDFS

序言主要是为了解决HDFS如何把NameNode升级为多个,之前只能部署一个NameNode加一个配合的计算节点 secondaryNameNode,注意secondaryNameNode 并不是主备模式的节点,而是用于协助NameNode做某些计算的节点,以提升吞吐量.cuiyaonan2000163.com如下内容来自于:https://zhuanlan.z…

SQL Server底层架构技术对比

背景 数据库是信息化的基石&#xff0c;支撑着整个业务系统&#xff0c;发挥着非常重要的作用&#xff0c;被喻为“IT的心脏”。因此&#xff0c;让数据库安全、稳定、高效地运行已经成为IT管理者必须要面对的问题。数据库在底层架构层面需要满足以下几点建设要求&#xff1a; …

es_MySQL、HBase、ElasticSearch三者对比详解

1、概念介绍 MySQL&#xff1a;关系型数据库&#xff0c;主要面向OLTP&#xff08;OLTP&#xff0c;也叫联机事务处理(Online Transaction Processing)&#xff09;&#xff0c;支持事务&#xff0c;支持二级索引&#xff0c;支持sql&#xff0c;支持主从、Group Replication&a…

SpringBoot技术快速入门

目录 Spring Boot是什么 Spring Boot 的特点 配置开发环境 创建 Spring Boot 项目 Maven 创建Spring Boot 项目 Spring Initializr 创建SpringBoot项目 启动 Spring Boot Spring Boot starter入门 SpringBoot基本设置 6.1SpringBoot设置端口号 6.2SpringBoot设置项目…