UDP套接字——(DGRAM)
/*********************程序相关信息*********************
* 程序编号:014
* 程序编写起始日期:2013.11.29
* 程序编写完成日期:2013.11.29
* 程序修改日期: 修改备注:
* 程序目的:学习linux UDP( DGRAM)
* 所用主要函数:socket() bind() recvfrom() sendto()
* 程序说明:
* 程序完成地点:
* *********************程序相关信息*********************/
#include <sys/types.h>
#include <netinet/in.h>
#include <netinet/ip.h>
#include <sys/socket.h> #include <stdio.h> #define BUFSIZE 1500 int main(void)
{
int sd;
struct sockaddr_in myend, hisend;
socklen_t hislen;
int ret;
char buf[BUFSIZE]; sd = socket(PF_INET, SOCK_DGRAM, 0);
if (sd == -1) {
perror("socket()");
goto socket_err;
}
//int bind(int sockfd, struct sockaddr *my_addr, int addrlen)
//sockfd:是由socket调用返回的文件描述符.
//addrlen:是sockaddr结构的长度.
//my_addr:是一个指向sockaddr的指针. 在<linux/socket.h>中有 sockaddr的定义
//struct sockaddr{
//unisgned short as_family;
//char sa_data[14];
//};
//不过由于系统的兼容性,我们一般不用这个头文件,而使用另外一个结构(struct sock
//addr_in) 来代替.在<linux/in.h>中有sockaddr_in的定义
//struct sockaddr_in{
//unsigned short sin_family;
//unsigned short int sin_port;
//struct in_addr sin_addr;
//unsigned char sin_zero[8];
//我们主要使用Internet所以sin_family一般为AF_INET,sin_addr设置为INADDR_ANY表
//示可以 和任何的主机通信,sin_port是我们要监听的端口号.sin_zero[8]是用来填充的
//.. bind将本地的端口同socket返回的文件描述符捆绑在一起.成功是返回0,失败的情况和
//socket一样
myend.sin_family = AF_INET;
myend.sin_port = htons(8899);
//i386芯片是低字节在内存地址的低端,高字节在高端,而alpha芯片却相反. 为了统一起来,在Li
//nux下面,有专门的字节转换函数.
//unsigned long int htonl(unsigned long int hostlong)
//unsigned short int htons(unisgned short int hostshort)
//unsigned long int ntohl(unsigned long int netlong)
//unsigned short int ntohs(unsigned short int netshort)
//在这四个转换函数中,h 代表host, n 代表 network.s 代表short l 代表long 第一个函
//数的意义是将本机器上的long数据转化为网络上的long. 其他几个函数的意义也差不多
//
myend.sin_addr.s_addr = INADDR_ANY; // man 7 ip
ret = bind(sd, (struct sockaddr *)&myend, sizeof(myend));
if (ret == -1) {
perror("bind()");
goto bind_err;
} hislen = sizeof(hisend);//??
while (1) {
//int recvfrom(int sockfd,void *buf,int len,unsigned int flags,struct socka
//ddr * from int *fromlen)
//int sendto(int sockfd,const void *msg,int len,unsigned int flags,struct s
//ockaddr *to int tolen)
//sockfd,buf,len的意义和read,write一样,分别表示套接字描述符,发送或接收的缓冲区
//及大小.recvfrom负责从sockfd接收数据,如果from不是NULL,那么在from里面存储了信息
//来源的情况,如果对信息的来源不感兴趣,可以将from和fromlen设置为NULL.sendto负责
//向to发送信息.此时在to里面存储了收信息方的详细资料.
ret = recvfrom(sd, buf, BUFSIZE, 0, (struct sockaddr *)&hisend, &hislen);
/* if error */ write(1, buf, ret); sendto(sd, "xxxxxx\n", 7, 0, (struct sockaddr *)&hisend, hislen);
} close(sd); return 0; bind_err:
close(sd);
socket_err:
return 1;
}
#include <sys/types.h>
#include <netinet/in.h>
#include <netinet/ip.h>
#include <sys/socket.h> #include <stdio.h> #define BUFSIZE 1500 int main(void)
{
int sd;
struct sockaddr_in myend, hisend;
socklen_t hislen;
int ret;
char buf[BUFSIZE]; sd = socket(PF_INET, SOCK_DGRAM, 0);
if (sd == -1) {
perror("socket()");
goto socket_err;
} hisend.sin_family = AF_INET;
hisend.sin_port = htons(8899);
// int inet_pton(int af, const char *src, void *dst); inet_pton(AF_INET, "192.168.1.111", &hisend.sin_addr);
// This function converts the character string src into a network address
// structure in the af address family, then copies the network address
//structure to dst.
//
#if 0
ret = bind(sd, (struct sockaddr *)&myend, sizeof(myend));
if (ret == -1) {
perror("bind()");
goto bind_err;
}
#endif hislen = sizeof(hisend);
while (1) {
ret = read(0, buf, BUFSIZE);
/* if error */
if (ret == 0) {
break;
}
// ssize_t sendto(int s, const void *buf, size_t len, int flags, const
//struct sockaddr *to, socklen_t tolen);
//Send, sendto, 和 sendmsg 用于向另一个套接字传递消息. Send 仅仅用于连接套接字,而 sendto 和 sendmsg
//可用于任何情况下.
//
//目标地址用 to 指定, tolen 定义其长度.消息的长度用 len 指定.
//如果消息太长不能通过下层协议,函数将返回 EMSGSIZE 错误,消息也不会被送出.
sendto(sd, buf, ret, 0, (struct sockaddr *)&hisend, hislen);
//ssize_t recvfrom(int s, void *buf, size_t len, int flags,
// struct sockaddr *from, socklen_t *fromlen)
ret = recvfrom(sd, buf, BUFSIZE, 0, (struct sockaddr *)&hisend, &hislen);
/* if error */ write(1, buf, ret);
} close(sd); return 0; bind_err:
close(sd);
socket_err:
return 1;
}
UDP套接字——(DGRAM)的更多相关文章
- python UDP套接字通信
UDPserver.py import socket #导入套接字模块 s = socket.socket(socket.AF_INET,socket.SOCK_DGRAM) # - socket.A ...
- 探索UDP套接字编程
UDP和TCP处于同一层网络模型中,也就是运输层,基于二者之上的应用有很多,常见的基于TCP的有HTTP.Telnet等,基于UDP有DNS.NFS.SNMP等.UDP是无连接,不可靠的数据协议服务, ...
- 【Python网络编程】利用Python进行TCP、UDP套接字编程
之前实现了Java版本的TCP和UDP套接字编程的例子,于是决定结合Python的学习做一个Python版本的套接字编程实验. 流程如下: 1.一台客户机从其标准输入(键盘)读入一行字符,并通过其套接 ...
- 【转】 探索UDP套接字编程
UDP和TCP处于同一层网络模型中,也就是运输层,基于二者之上的应用有很多,常见的基于TCP的有HTTP.Telnet等,基于UDP有DNS.NFS.SNMP等.UDP是无连接,不可靠的数据协议服务, ...
- 【nodejs】创建udp套接字的类型参数的含义
nodejs在创建udp套接字的时候,需要传入一个类型参数.有两种类型参数可供选择:udp4和udp6.udp4对应的就是ipv4,udp6对应的是ipv6.
- JavaTCP和UDP套接字编程
在我们刚开始入门Java后端的时候可能你会觉得有点复杂,包含了很多杂七杂八的知识,例如文件上传下载,监听器,JDBC,请求重定向,请求转发等等(当然也没有很多),但是我们自己真正的去开发一个小型网站( ...
- 计算机网络实验 UDP套接字编程
这是个傻瓜式操作教程 西科大计算机网络实验 UDP套接字编程 我用自己的Ubuntu16.04来举例,实验室的是虚拟机,差不多 只针对第三个题目,修改服务器来通过响应客户端发送的GetTime并发送给 ...
- UDP套接字编程 返回系统时间
计算机网络实验 简单UDP套接字编程 这是学校老师自己改进了一点的题目.我预习了好久才搞明白,同学来问的时候,一大堆简单问题实在是不想回答...所以,这时候我觉得博客是个好东西! 我的任务是做客户端和 ...
- Python之路(第三十二篇) 网络编程:udp套接字、简单文件传输
一.UDP套接字 服务端 # udp是无链接的,先启动哪一端都不会报错 # udp没有链接,与tcp相比没有链接循环,只有通讯循环 server = socket.socket(socket.AF_I ...
- <unix网络编程>UDP套接字编程
典型的UDP客户/服务器程序的函数调用如下: 1.缓冲区 发送缓冲区用虚线表示,任何UDP套接字都有发送缓冲区,不过该缓冲区仅能表示写到该套接字的UDP数据报的上限.如果应用进程写一个大于套接字缓冲区 ...
随机推荐
- VS code配置docker的shell环境
今天尝试了下使用docker来做虚拟机,几番折腾后终于搞定可以用了,但是想着每次都要在命令行敲半天也太恶心了,所以就找了一下可视化的管理工具 首先说下,我的docker主机环境是windows10,用 ...
- 长沙理工大学第十二届ACM大赛-重现赛 L - 选择困难症
题目描述 小L有严重的选择困难症. 早上起床后,需要花很长时间决定今天穿什么出门. 假设一共有k类物品需要搭配选择,每类物品的个数为Ai,每个物品有一个喜欢值Vj,代表小L对这件物品的喜欢程度. 小L ...
- `__pycache__` 是什么
为了提高模块加载的速度,每个模块都会在 __pycache__ 文件夹中放置该模块的预编译模块,命名为 module.version.pyc, version 是模块的预编译版本编码,一般都包含 Py ...
- 最短路——spfa
适用范围:给定的图存在负权边,这时类似Dijkstra等算法便没有了用武之地,而Bellman-Ford算法的复杂度又过高,SPFA算法便派上用场了. 我们约定有向加权图G不存在负权回路,即最短路径一 ...
- C#封装StackExchange.Redis操作
using System; using StackExchange.Redis; using System.Collections.Generic; using System.Linq; using ...
- 安卓 Activity Fragment 生命周期
韩梦飞沙 韩亚飞 313134555@qq.com yue31313 han_meng_fei_sha 活动: 创建->启动->获得焦点->暂停->停止->销毁 ...
- java 线程 wait join sleep yield notify notifyall synchronized
韩梦飞沙 韩亚飞 313134555@qq.com yue31313 han_meng_fei_sha 休息方法 : 在指定时间内 让该线程 暂停, 不会释放 锁标志. 等待方法: 让 该 线 ...
- logN判点是否在凸多边形内 HRBUSTOJ1429
就是利用叉积的性质,如果向量A1到向量A2是顺时针则叉积为负反之为正. 然后我们可以二分的判断找到一个点恰被两条射线夹在一起. 然后我们再判断是否l,r这两个点所连直线与点的关系. 具体资料可以参照这 ...
- CodeForces 1063C. Dwarves, Hats and Extrasensory Abilities 交互
题目大意: 依次给定$n$个点的颜色,要求给定这$n$个点的坐标以及一条可以把他们分成两部分的直线 强制在线(交互) $n \leqslant 30$ 感觉自己真像一个乱搞... 我们只考虑把点放在最 ...
- WEB架构师成长之路 二
法宝一:牛人爱惜自己的时间. 时间就是金钱,时间就是生命,时间如同健康一样,如果时间都没有,那成功也就是浮云了.所以牛人总是很爱惜自己的时间,总是在想办法提高自己的做事效率.我突然想了起来,我QQ里有 ...