一个简单的基于epoll的udp接收
---
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接收的更多相关文章
- 并发编程概述 委托(delegate) 事件(event) .net core 2.0 event bus 一个简单的基于内存事件总线实现 .net core 基于NPOI 的excel导出类,支持自定义导出哪些字段 基于Ace Admin 的菜单栏实现 第五节:SignalR大杂烩(与MVC融合、全局的几个配置、跨域的应用、C/S程序充当Client和Server)
并发编程概述 前言 说实话,在我软件开发的头两年几乎不考虑并发编程,请求与响应把业务逻辑尽快完成一个星期的任务能两天完成绝不拖三天(剩下时间各种浪),根本不会考虑性能问题(能接受范围内).但随着工 ...
- 通过Dapr实现一个简单的基于.net的微服务电商系统(四)——一步一步教你如何撸Dapr之订阅发布
之前的章节我们介绍了如何通过dapr发起一个服务调用,相信看过前几章的小伙伴已经对dapr有一个基本的了解了,今天我们来聊一聊dapr的另外一个功能--订阅发布 目录:一.通过Dapr实现一个简单的基 ...
- 通过Dapr实现一个简单的基于.net的微服务电商系统
本来想在Dpar 1.0GA时发布这篇文章,由于其他事情耽搁了放到现在.时下微服务和云原生技术如何如荼,微软也不甘示弱的和阿里一起适时推出了Dapr(https://dapr.io/),园子里关于da ...
- 通过Dapr实现一个简单的基于.net的微服务电商系统(二)——通讯框架讲解
首先感谢张队@geffzhang公众号转发了上一篇文章,希望广大.neter多多推广dapr,让云原生更快更好的在.net这片土地上落地生根. 目录:一.通过Dapr实现一个简单的基于.net的微服务 ...
- 通过Dapr实现一个简单的基于.net的微服务电商系统(二十)——Saga框架实现思路分享
今天这篇博文的主要目的是分享一下我设计Saga的实现思路来抛砖引玉,其实Saga本身非常的类似于一个简单的工作流体系,相比工作流不一样的部分在于它没有工作流的复杂逻辑处理机制(比如会签),没有条件分支 ...
- struts1:(Struts重构)构建一个简单的基于MVC模式的JavaWeb
在构建一个简单的基于MVC模式的JavaWeb 中,我们使用了JSP+Servlet+JavaBean构建了一个基于MVC模式的简单登录系统,但在其小结中已经指出,这种模式下的Controller 和 ...
- 一个简单的基于 DirectShow 的播放器 2(对话框类)
上篇文章分析了一个封装DirectShow各种接口的封装类(CDXGraph):一个简单的基于 DirectShow 的播放器 1(封装类) 本文继续上篇文章,分析一下调用这个封装类(CDXGrap ...
- 一个简单的基于 DirectShow 的播放器 1(封装类)
DirectShow最主要的功能就是播放视频,在这里介绍一个简单的基于DirectShow的播放器的例子,是用MFC做的,今后有机会可以基于该播放器开发更复杂的播放器软件. 注:该例子取自于<D ...
- 构建一个简单的基于MVC模式的JavaWeb
零晨三点半了,刚刚几个兄弟一起出去吼歌,才回来,这应该是我大学第二次去K歌,第一次是大一吧,之后每次兄弟喊我,我都不想去,因为我还是很害怕去KTV,或许是因为那里是我伤心的地方,也或许是因为我在那里失 ...
随机推荐
- Redis高并发处理常见问题及解决方案
1. 大型电商系统高流量系统设计 场景: 大量电商系统每天要处理上亿请求,其中大量请求来自商品访问.下单.商品的详情是时刻变化,由于请求量过大,不会频繁去服务端获取商品信息,导致服务器压力极大.需要用 ...
- Linux 中的五种 IO 模型
Linux 中的五种 IO 模型 在正式开始讲Linux IO模型前,比如:同步IO和异步IO,阻塞IO和非阻塞IO分别是什么,到底有什么区别?不同的人在不同的上下文下给出的答案是不同的.所以先限定一 ...
- 【模板】Splay(伸展树)普通平衡树(数据加强版)/洛谷P6136
题目链接 https://www.luogu.com.cn/problem/P6136 题目大意 需要写一种数据结构,来维护一些非负整数( \(int\) 范围内)的升序序列,其中需要提供以下操作: ...
- Kubernetes:应用自动扩容、收缩与稳定更新
在前面我们已经学习到了 Pod 的扩容.滚动更新等知识,我们可以手动为 Deployment 等设置 Pod 副本的数量,而这里会继续学习 关于 Pod 扩容.收缩 的规则,让 Pod 根据节点服务器 ...
- Shell学习(四)——shell中各种括号的作用
参考博客: [1]shell中各种括号的作用().(()).[].[[]].{} [2]shell中的单层大/中/小括号.双层大中小括号.命令替换等 一.前言 目录 单括号() 双括号(( )) 单中 ...
- 数组实现堆栈——Java实现
1 package struct; 2 3 4 //接口 5 interface IArrayStack{ 6 //栈的容量 7 int length(); 8 //栈中元素个数(栈大小) 9 int ...
- 视频框架 Vitamio使用
转自http://blog.csdn.net/u010181592/article/category/5893483 1.在https://github.com/yixia/VitamioBundle ...
- Output of C++ Program | Set 7
Predict the output of following C++ programs. Question 1 1 class Test1 2 { 3 int y; 4 }; 5 6 class T ...
- Mysql多字段模糊查询
MySQL同一字段多值模糊查询 一. 同一字段多值模糊查询,使用多个or进行链接,效率不高,但没有更好的解决方案.(有看到CHARINDEX 关键字,可查询结果并不是模糊,举个栗子 例如SELECT ...
- FindUserByPageServlet
package com.hopetesting.web.servlet;import com.hopetesting.domain.PageBean;import com.hopetesting.do ...