UDP通讯程序设计

一、函数化

1.1服务器使用的函数

  创建socket----->socket

  绑定地址-------->bind

  接受数据-------->recvfrom

  发送数据-------->sendto

  结束连接-------->close

1.2客户机使用函数

  创建套接字------>socket

  发送数据-------->sento

  接受数据-------->recvfrom

  结束连接-------->close

二、函数学习

2.1 发送数据sendto

2.1.1包含头文件

  #include <sys/types.h>
  #include <sys/socket.h>

2.1.2函数原型

  ssize_t sendto(int sockfd, const void *buf, size_t len, int flags,
const struct sockaddr *dest_addr, socklen_t addrlen);

2.1.3函数参数

  sockfd:创建的套接字

  *buf:要发送的数据地址

  len:数据长度

  flags:标识符

  dest_addr:目的机地址

  addrlen:地址长度

2.1.4返回值

  实际发送的数据量

2.2接收数据recvfrom

2.2.1包含头文件

  #include <sys/types.h>
  #include <sys/socket.h>

2.2.2函数原型

  ssize_t recvfrom(int sockfd, void *buf, size_t len, int flags,
    struct sockaddr *src_addr, socklen_t *addrlen);

2.2.3函数参数

  sockfd:创建的套接字

  *buf:数据存放的地址

  len:数据长度

  flags:标识符

  dest_addr:数据来源方方的地址

  addrlen:地址长度的指针

2.2.4返回值

  以字节计数的消息长度,若无可用消息或对方已经按序结束则返回0,若出错则返回-1

三、编写服务器代码

  touch  udp_server.c

  chmod 777 udp_server.c

 #include <stdio.h>
#include <string.h>
#include <sys/socket.h>
#include <netinet/in.h> #define portnum 8888
#define msg_size 128
int main()
{
int sockfd;
char buffer[msg_size];
struct sockaddr_in server_addr;
struct sockaddr_in client_addr;
int addrlen;
int n;
//1.创建套接字
sockfd = socket(AF_INET,SOCK_DGRAM,); //2.绑定地址
bzero(&server_addr,sizeof(struct sockaddr_in));
server_addr.sin_family = AF_INET;
server_addr.sin_port = htons(portnum);
server_addr.sin_addr.s_addr = htonl(INADDR_ANY);
bind(sockfd,(struct sockaddr *)(&server_addr),sizeof(struct sockaddr)); //3.接受数据
while()
{
addrlen = sizeof(struct sockaddr); //获取数据长度地址
bzero(buffer,sizeof(buffer));
n = recvfrom(sockfd,buffer,msg_size,,(struct sockaddr *)(&client_addr),&addrlen);
buffer[n] = ;
printf("server received :%s\n",buffer);
}
//4.结束连接
close(sockfd);
return ;
}

编译运行:

四、编写客户机代码

  touch udp_client,c

  chmod 777 udp_client.c

#include <stdio.h>
#include <string.h>
#include <sys/socket.h>
#include <netinet/in.h> #define buffer_size 128
#define portnum 8888
int main(int argc,char **argv[])
{
int sockfd;
char buffer[buffer_size];
struct sockaddr_in server_addr; if(argc != )
{
printf("usage: %s server_ip\n",argv[]);
exit();
}
//1.创建套接字
sockfd = socket(AF_INET,SOCK_DGRAM,); //初始化服务器地址
bzero(&server_addr,sizeof(struct sockaddr_in));
server_addr.sin_family = AF_INET;
server_addr.sin_port = htons(portnum);
inet_aton(argv[],&server_addr.sin_addr); //2.发送数据
while()
{
printf("please input char: \n");
fgets(buffer,buffer_size,stdin);
sendto(sockfd,buffer,strlen(buffer),,(struct sockaddr *)(&server_addr),sizeof(struct sockaddr));
bzero(buffer,buffer_size);
} //3.关闭连接
close(sockfd);
return ; }

编译运行:

4.1则可以看到服务器运行结果

UDP通讯程序设计的更多相关文章

  1. UDP通讯程序设计---6

    一.函数化 1.1服务器使用的函数 创建socket----->socket 绑定地址-------->bind 接受数据-------->recvfrom 发送数据-------- ...

  2. TCP通讯程序设计

    TCP通讯程序设计 这里主要包含客户机和服务器的编程. 一.编程模型函数化 使用函数说明:socket的理解 服务器: 创建socket使用函数----->socket 绑定地址使用函数---- ...

  3. C#中的TCP通讯与UDP通讯

    最近做了一个项目,主要是给Unity3D和实时数据库做通讯接口.虽然方案一直在变:从开始的UDP通讯变为TCP通讯,然后再变化为UDP通讯;然后通讯的对象又发生改变,由与数据库的驱动进行通讯(主动推送 ...

  4. LWIP裸机环境下实现TCP与UDP通讯

    前面移植了LWIP,并且简单的实用了DHCP的功能,今天来使用一下实际的数据通讯的功能 首先是实现TCP客户端,我先上代码 #ifndef __TCP_CLIENT_H_ #define __TCP_ ...

  5. JAVA之旅(三十二)——JAVA网络请求,IP地址,TCP/UDP通讯协议概述,Socket,UDP传输,多线程UDP聊天应用

    JAVA之旅(三十二)--JAVA网络请求,IP地址,TCP/UDP通讯协议概述,Socket,UDP传输,多线程UDP聊天应用 GUI写到一半电脑系统挂了,也就算了,最多GUI还有一个提示框和实例, ...

  6. LWIP裸机环境下实现TCP与UDP通讯(转)

    源: LWIP裸机环境下实现TCP与UDP通讯

  7. java基础55 UDP通讯协议和TCP通讯协议

    本文知识点(目录): 1.概述    2.UDP通讯协议    3.TCPP通讯协议 1.概述 1.在java中网络通讯作为Socket(插座)通讯,要求两台都必须安装socket.    2.不同的 ...

  8. UDP通讯

    上一篇有说到TCP通讯,这篇来谈谈UDP通讯方式 基于Udp协议是无连接模式通讯,占用资源少,响应速度快,延时低.至于可靠性,可通过应用层的控制来满足.(不可靠连接) (1).建立一个套接字(Sock ...

  9. QUdpSocket-Qt使用Udp通讯实现服务端和客户端

    版权声明:若无来源注明,Techie亮博客文章均为原创. 转载请以链接形式标明本文标题和地址: 本文标题:QUdpSocket-Qt使用Udp通讯实现服务端和客户端     本文地址:https:// ...

随机推荐

  1. Struts2学习笔记《三》

      Struts2的工作原理图: struts的用法:

  2. C#之文本操作

    [转载]C#文件操作大全(SamWang) 文件与文件夹操作主要用到以下几个类: 1.File类: 提供用于创建.复制.删除.移动和打开文件的静态方法,并协助创建 FileStream 对象. msd ...

  3. poj 1797(并查集)

    http://poj.org/problem?id=1797 题意:就是从第一个城市运货到第n个城市,最多可以一次运多少货. 输入的意思分别为从哪个城市到哪个城市,以及这条路最多可以运多少货物. 思路 ...

  4. RRD

    http://my.oschina.net/u/1458120/blog/208857

  5. DNS基础及域名系统架构

    本文出自   http://blog.csdn.net/shuangde800 ------------------------------------------------------------ ...

  6. HDU 4873 ZCC Loves Intersection(JAVA、大数、推公式)

    在一个D维空间,只有整点,点的每个维度的值是0~n-1 .现每秒生成D条线段,第i条线段与第i维度的轴平行.问D条线段的相交期望. 生成线段[a1,a2]的方法(假设该线段为第i条,即与第i维度的轴平 ...

  7. codeforces 582A. GCD Table 解题报告

    题目链接:http://codeforces.com/problemset/problem/582/A 网上很多题解,就不说了,直接贴代码= = 官方题解: http://codeforces.com ...

  8. spfa(模板)

    spfa作为图论中的常用算法,深受各类出题人和各位OIer的喜爱: so,为了给大众创造福利,宝宝在此奉上spfa大发的思路和模板:以感谢社会, 感谢CCF,感谢CCTV, 感谢我的老师,感谢同学们, ...

  9. NEFU 84 五指山 (扩展欧几里得)

    五指山 Problem:84 Time Limit:1000ms Memory Limit:65536K Description 西游记中孙吾空大闹天宫,如来佛祖前来降伏他,说道:"我与你打 ...

  10. ios 宏定义 系统版本 判定

    当需要判断iOS系统版本的时候,相信很多人都会这么干: #define SystemVersion [[UIDevice currentDevice] systemVersion].floatValu ...