---

  1 #include <iostream>
2 #include <sys/epoll.h>
3 #include <fcntl.h>
4 #include <thread>
5 #include <chrono>
6 #include <pthread.h>
7 #include <sys/socket.h>
8 #include <arpa/inet.h>
9 #include <netinet/in.h>
10 #include <sys/time.h>
11 #include <sys/select.h>
12 #include <unistd.h>
13 #include <string.h>
14
15 #include <errno.h>
16
17
18 using namespace std;
19
20 int main(int argc, char *argv[])
21 {
22
23 int udpfd = 0;
24 char arr_ip4_local[] = {"192.168.244.128"};
25 char arr_ip4_dst[] = {"10.1.1.5"};
26
27
28 struct sockaddr_in addr_dst;
29 struct sockaddr_in addr_local;
30 bzero(&addr_dst, sizeof(struct sockaddr_in));
31 bzero(&addr_local, sizeof(struct sockaddr_in));
32
33 addr_dst.sin_port = htons(12345);
34 addr_dst.sin_family = AF_INET;
35 // addr_dst.sin_addr.s_addr = htonl(INADDR_ANY);
36 inet_pton(AF_INET, arr_ip4_dst, &addr_dst.sin_addr.s_addr);
37
38 addr_local.sin_family = AF_INET;
39 addr_local.sin_port = htons(12345);
40 //inet_pton(AF_INET, arr_ip4_local, &addr_local.sin_addr.s_addr);
41 addr_local.sin_addr.s_addr = htonl(INADDR_ANY);
42
43 // socket
44 udpfd = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP);
45 if (0 > udpfd)
46 {
47 std::cout << "created failed\n";
48 return 0;
49 }
50
51
52 // bind local address to recv and send data
53 int ret_val = bind(udpfd, (struct sockaddr*)&addr_local, sizeof(addr_local));
54 if (0 != ret_val)
55 {
56 std::cout << "bind error, id = " << errno << "\n";
57 close(udpfd);
58 return 0;
59 }
60
61
62 // epoll operation
63 struct epoll_event event;
64 struct epoll_event event_wait;
65
66 int epoll_fd = epoll_create(10);
67 if ( -1 == epoll_fd )
68 {
69 std::cout << "epoll_create error, id = " << errno << "\n";
70 close(udpfd);
71 return 0;
72 }
73
74 //
75 event.data.fd = 0;
76 event.events = EPOLLIN;
77
78 // register functions
79 ret_val = epoll_ctl(epoll_fd, EPOLL_CTL_ADD, 0, &event);
80 if ( -1 == ret_val )
81 {
82 std::cout << "epoll_ctl error, id = " << errno << "\n";
83 close(udpfd);
84
85 return 0;
86 }
87
88 //
89 event.data.fd = udpfd;
90 event.events = EPOLLIN;
91 ret_val = epoll_ctl(epoll_fd, EPOLL_CTL_ADD, udpfd, &event);
92 if ( -1 == ret_val )
93 {
94 std::cout << "epoll_ctl error, udpfd, id = " << errno << "\n";
95 close(udpfd);
96
97 return 0;
98 }
99
100 // listen
101 struct sockaddr_in addr_recv;
102 char arr_recv[1024] = {0};
103 int addr_recv_len = sizeof(addr_recv);
104 bzero(&addr_recv, addr_recv_len);
105 socklen_t recv_len = sizeof(addr_recv);
106
107 int quit_index = 1;
108 int quit_count = 10;
109
110
111 while (1)
112 {
113 std::cout << "wait for connecting: ";
114 ret_val = epoll_wait(epoll_fd, &event_wait, 2, -1);
115 if (-1 == ret_val)
116 {
117 std::cout << "error, while, id = " << errno << "\n";
118 close(udpfd);
119 return 0;
120 }
121
122 else if (0 < ret_val)
123 {
124 if ( (udpfd == event_wait.data.fd)
125 &&
126 (EPOLLIN == (event_wait.events & EPOLLIN)) )
127 {
128 ret_val = recvfrom(udpfd, arr_recv, 1024, 0, (struct sockaddr*)&addr_recv, &recv_len);
129 std::cout << "\n recvfrom = " << ret_val << "\n";
130 bzero(&addr_recv, addr_recv_len);
131 quit_index ++;
132 if ( quit_index >= quit_count )
133 break;
134 }
135
136 }
137 else if (0 == ret_val)
138 {
139 std::cout << "\nwhile timeout\n";
140 }
141 else
142 {
143
144 }
145 }
146
147 close(udpfd);
148
149 return 0;
150 }

----

一个简单的基于epoll的udp接收的更多相关文章

  1. 并发编程概述 委托(delegate) 事件(event) .net core 2.0 event bus 一个简单的基于内存事件总线实现 .net core 基于NPOI 的excel导出类,支持自定义导出哪些字段 基于Ace Admin 的菜单栏实现 第五节:SignalR大杂烩(与MVC融合、全局的几个配置、跨域的应用、C/S程序充当Client和Server)

    并发编程概述   前言 说实话,在我软件开发的头两年几乎不考虑并发编程,请求与响应把业务逻辑尽快完成一个星期的任务能两天完成绝不拖三天(剩下时间各种浪),根本不会考虑性能问题(能接受范围内).但随着工 ...

  2. 通过Dapr实现一个简单的基于.net的微服务电商系统(四)——一步一步教你如何撸Dapr之订阅发布

    之前的章节我们介绍了如何通过dapr发起一个服务调用,相信看过前几章的小伙伴已经对dapr有一个基本的了解了,今天我们来聊一聊dapr的另外一个功能--订阅发布 目录:一.通过Dapr实现一个简单的基 ...

  3. 通过Dapr实现一个简单的基于.net的微服务电商系统

    本来想在Dpar 1.0GA时发布这篇文章,由于其他事情耽搁了放到现在.时下微服务和云原生技术如何如荼,微软也不甘示弱的和阿里一起适时推出了Dapr(https://dapr.io/),园子里关于da ...

  4. 通过Dapr实现一个简单的基于.net的微服务电商系统(二)——通讯框架讲解

    首先感谢张队@geffzhang公众号转发了上一篇文章,希望广大.neter多多推广dapr,让云原生更快更好的在.net这片土地上落地生根. 目录:一.通过Dapr实现一个简单的基于.net的微服务 ...

  5. 通过Dapr实现一个简单的基于.net的微服务电商系统(二十)——Saga框架实现思路分享

    今天这篇博文的主要目的是分享一下我设计Saga的实现思路来抛砖引玉,其实Saga本身非常的类似于一个简单的工作流体系,相比工作流不一样的部分在于它没有工作流的复杂逻辑处理机制(比如会签),没有条件分支 ...

  6. struts1:(Struts重构)构建一个简单的基于MVC模式的JavaWeb

    在构建一个简单的基于MVC模式的JavaWeb 中,我们使用了JSP+Servlet+JavaBean构建了一个基于MVC模式的简单登录系统,但在其小结中已经指出,这种模式下的Controller 和 ...

  7. 一个简单的基于 DirectShow 的播放器 2(对话框类)

    上篇文章分析了一个封装DirectShow各种接口的封装类(CDXGraph):一个简单的基于 DirectShow 的播放器  1(封装类) 本文继续上篇文章,分析一下调用这个封装类(CDXGrap ...

  8. 一个简单的基于 DirectShow 的播放器 1(封装类)

    DirectShow最主要的功能就是播放视频,在这里介绍一个简单的基于DirectShow的播放器的例子,是用MFC做的,今后有机会可以基于该播放器开发更复杂的播放器软件. 注:该例子取自于<D ...

  9. 构建一个简单的基于MVC模式的JavaWeb

    零晨三点半了,刚刚几个兄弟一起出去吼歌,才回来,这应该是我大学第二次去K歌,第一次是大一吧,之后每次兄弟喊我,我都不想去,因为我还是很害怕去KTV,或许是因为那里是我伤心的地方,也或许是因为我在那里失 ...

随机推荐

  1. sprint-boot 日志

    市面上的日志框架: JUL.JCL.Jboss-logging.logback.log4j.log4j2.slf4j.... SpringBoot:底层是Spring框架,Spring框架默认是用JC ...

  2. miRNA分析--比对(二)

    miRNA分析--数据过滤(一) 在比对之前为了减少比对时间,将每一个样本中的reads进行合并,得到fasta格式,其命名规则如下: 样本_r数子_x数字 r 中的数字表示reads序号: x 中的 ...

  3. python-django-常用models里面的Field

    1.models.AutoField 自增列 = int(11) 如果没有的话,默认会生成一个名称为 id 的列 如果要显式的自定义一个自增列,必须设置primary_key=True. 2.mode ...

  4. CentOS6源码安装zabbix服务器

    1.下载安装包并解压 2.预环境搭建 3.创建zabbix用户,编译安装zabbix 4.配置mysql 5.配置zabbix-server 6.配置apache和php 7.添加开机自启动 1 yu ...

  5. 在Kubernetes上安装MySQL-PXC集群

    官方部署文档地址:https://www.percona.com/doc/kubernetes-operator-for-pxc/kubernetes.html 一.部署方式 示例在k8s集群(至少3 ...

  6. day13 装饰器与语法糖

    day13 装饰器与语法糖 一.装饰器 1.什么是装饰器 装饰器就是装饰别人的工具,具体是指为被装饰者添加新功能 装饰器->函数 被装饰者->函数 2.为何要用装饰器 装饰器的核心思想:( ...

  7. C语言中的使用内存的三段

    1.正文段即代码和赋值数据段 一般存放二进制代码和常量 2.数据堆段 动态分配的存储区在数据堆段 3.数据栈段 临时使用的变量在数据栈段 典例 若一个进程实体由PCB.共享正文段.数据堆段和数据栈段组 ...

  8. Android 小知识

    1.判断sd卡是否存在 boolean sdCardExist = Environment.getExternalStorageState().equals(android.os.Environmen ...

  9. RAC(Reactive Cocoa)常见的类

    导入ReactiveCocoa框架 在终端,进入Reactive Cocoa文件下 创建podfile 打开该文件 并配置 use_frameworks! pod 'ReactiveCocoa', ' ...

  10. 【Java 8】Stream通过reduce()方法合并流为一条数据示例

    在本页中,我们将提供 Java 8 Stream reduce()示例. Stream reduce()对流的元素执行缩减.它使用恒等式和累加器函数进行归约. 在并行处理中,我们可以将合并器函数作为附 ...