转自http://www.cppblog.com/peija/archive/2010/10/07/128941.html

eventfd 在内核版本,2.6.22以后有效。查看内核版本可以用命令 uname -r 。

1 #include <sys/eventfd.h>
2 int eventfd(unsigned int initval, int flags);

这个函数会创建一个 事件对象 (eventfd object), 用来实现,进程(线程)间 的 等待/通知(wait/notify) 机制. 内核会为这个对象维护一个64位的计数器(uint64_t)。
 并且使用第一个参数(initval)初始化这个计数器。调用这个函数就会返回一个新的文件描述符(event object)。2.6.27版本开始可以按位设置第二个参数(flags)。
有如下的一些宏可以使用:

EFD_NONBLOCK , 功能同open(2) 的O_NONBLOCK,设置对象为非阻塞状态,如果没有设置这个状态的话,read(2)读eventfd,并且计数器的值为0 就一直堵塞在read调用当中,要是设置了这个标志, 就会返回一个 EAGAIN 错误(errno = EAGAIN)。效果也如同 额外调用select(2)达到的效果。

EFD_CLOEXEC 我的理解是,这个标识被设置的话,调用exec后会自动关闭文件描述符,防止泄漏。

如果是2.6.26或之前版本的内核,flags 必须设置为0。

创建这个对象后,可以对其做如下操作。

write 将缓冲区写入的8字节整形值加到内核计数器上。

read 读取8字节值, 并把计数器重设为0. 如果调用read的时候计数器为0, 要是eventfd是阻塞的, read就一直阻塞在这里,否则就得到 一个EAGAIN错误。
如果buffer的长度小于8那么read会失败, 错误代码被设置成 EINVAL。

poll select epoll

close 当不需要eventfd的时候可以调用close关闭, 当这个对象的所有句柄都被关闭的时候,内核会释放资源。 为什么不是close就直接释放呢, 如果调用fork 创建
进程的时候会复制这个句柄到新的进程,并继承所有的状态。

下面是一个例子

 1 #include <sys/eventfd.h>
 2 #include <unistd.h>
 3 #include <stdio.h>
 4 #include <stdint.h>
 5 #include <stdlib.h>
 6 #include <errno.h>
 7
 8 #define handle_error(msg) \
 9     do { perror(msg); exit(1); } while (0)
10
11 int main( int argc, char **argv )
12 {
13     uint64_t u;
14     ssize_t s;
15     int j;
16     if ( argc < 2 ) {
17         fprintf(stderr, "input <num> in command argument");
18         exit(1);
19     }
20
21     int efd;
22     if ( (efd = eventfd(0, EFD_NONBLOCK)) == -1 )
23             handle_error("eventfd failed");
24
25
26     switch (fork()) {
27         case 0:
28             for( j = 1; j < argc; j ++ ) {
29                 printf("Child writing %s to efd\n", argv[j] );
30
31                 u = strtoull(argv[j], NULL, 0);  /* analogesly atoi */
32                 s = write(efd, &u, sizeof(uint64_t)); /* append u to counter */
33                 if ( s != sizeof(uint64_t) )
34                     handle_error("write efd failed");
35
36             }
37             printf("child completed write loop\n");
38
39             exit(0);
40         default:
41             sleep (2);
42
43             printf("parent about to read\n");
44             s = read(efd, &u, sizeof(uint64_t));
45             if ( s != sizeof(uint64_t) ) {
46                 if (errno = EAGAIN) {
47                     printf("Parent read value %d\n", s);
48                     return 1;
49                 }
50                 handle_error("parent read failed");
51             }
52             printf("parent read %d , %llu (0x%llx) from efd\n",
53                     s, (unsigned long long)u, (unsigned long long) u);
54             exit(0);
55
56         case -1:
57             handle_error("fork ");
58     }
59     return 0;
60 }

这个API还是很有用的, 当你想要编写并发型服务器的时候,aventfd 可以完美取代 pipe去通知(唤醒)其他的进程(线程)。比如经典的异步IO reactor/selector 
应用场景,去唤醒select的调用。他的缓冲区处理非常方便, 规定只有8字节。

转载于:https://www.cnblogs.com/minuse/p/7472795.html

Linux 新api eventfd(转)相关推荐

  1. 百度发布 PaddlePaddle 新 API;微软更新 Linux 平台虚拟机 DSVM 等 | AI 开发者头条

    ▲内容预览 百度发布 PaddlePaddle 新 API,以及免费手册<使用 PaddlePaddle 进行深度学习> 微软更新 Linux 平台的数据科学虚拟机(DSVM) 谷歌发布机 ...

  2. PyTorch 1.9发布,支持新API,可在边缘设备中执行

    点击上方"视学算法",选择加"星标"或"置顶" 重磅干货,第一时间送达 来源丨机器之心 编辑丨极市平台 导读 PyTorch 团队发布了 P ...

  3. linux 函数手册 在线,Linux系统API函数手册

    Linux系统API函数手册 (34页) 本资源提供全文预览,点击全文预览即可全文预览,如果喜欢文档就下载吧,查找使用更方便哦! 11.90 积分 (一)文件操作篇 1.creat(建立文件)头文件1 ...

  4. Libev源码分析07:Linux下的eventfd简介

    #include <sys/eventfd.h>int eventfd(unsigned int initval, int flags); eventfd创建一个eventfd对象,该对象 ...

  5. api有哪些 javasocket_Java Socket编程以及与Linux Socket API关系

    Socket 编程(基于Linux) Socket独立于具体协议的网络编程接口,在ISO模型中,主要位于会话层和传输层之间:在通用的计算机网络五层模型中,主要位于应用层和传输层之间. Linux So ...

  6. api有哪些 javasocket_简单hello/hi程序、分析及Java Socket API与Linux Socket API对比

    1.Socket 定义 套接字(socket)是一个抽象层,应用程序可以通过它发送或接收数据,可对其进行像对文件一样的打开.读写和关闭等操作.套接字允许应用程序将I/O插入到网络中,并与网络中的其他应 ...

  7. hbase建索引java api_hbase java api样例(版本1.3.1,新API)

    hbase版本:1.3.1 目的:HBase新API的使用方法. 尝试并验证了如下几种java api的使用方法. 1.创建表 2.创建表(预分区) 3.单条插入 4.批量插入 5.批量插入(客户端缓 ...

  8. python封装api linux_python Socket编程-python API 与 Linux Socket API之间的关系

    python socket编程 by SA19225409 地址协议家族 Python 支持 AF_UNIX. AF_NETLINK. AF_TIPC 和 AF_INET 家族 AF_UNIX 基于本 ...

  9. hbase开发环境搭建及运行hbase小实例(HBase 0.98.3新api)

    问题导读: 1.如何搭建hbase开发环境? 2.HTableDescriptor初始化产生了那些变化? 3.eclipse如何连接hbase集群? hbase开发环境搭建与hadoop开发环境搭建差 ...

最新文章

  1. gateway 内存溢出问题_带你学习jvm java虚拟机 arthas/性能调优/故障排除/gc回收/内存溢出等...
  2. QTP之web常用对象
  3. 给一份Webservice接口通用实现!!
  4. hdu 4468 spy 极其精彩的一道kmp灵活运用题
  5. C++ JSON库:JSON for Morden C++
  6. NuGet Error:Unable to find version ‘0.3.3.0‘ of package ‘glog.overlay-x64_v120_Release_dynamic‘.
  7. 解读Tom介绍的Oracle Database 12c的12个新特性
  8. git 公钥提交代码_Git自由之章 - 关于SSH 公钥
  9. 判断 360浏览器极速 / 兼容模式
  10. VS2010SP1中文版安装问题
  11. Gauntlet风险评级上线: DeFi杠杆率多高?会不会崩盘?
  12. 用c写一个等腰三角星星图案
  13. numpy找非零元素并计数 numpy.nonzero 和 numpy.count_nonzero
  14. 怎么修改和编辑PDF文件中的文字内容
  15. 文本挖掘 包含中英文数据预处理以及分析
  16. 【java基础】IO流是啥?有啥用?(上)
  17. 【天华学术】古代文学论文:酒文化传播中唐代文学的作用分析(节选)
  18. JSP设置Excel表格换行_Excel中快速将阿拉伯数字转化为大写文字的妙招
  19. Android Webview录音功能与原生录音实现
  20. STM32内部参考电压+DMA精准采集电池电压

热门文章

  1. Python 相对路径问题:“No such file or directory“,原因及解决方法
  2. Python 技术篇-用smtplib和email库实现邮件发送并展示本地图片实例演示
  3. 用两个栈(C++)实现插入排序
  4. CTFshow 命令执行 web120
  5. CTFshow 爆破 web22
  6. 利用python下载网页到本地(python3)
  7. poj 3150 Cellular Automaton(迷糊,但原理是用的快速幂)
  8. 指向常对象的指针变量
  9. Python标准库01 正则表达式 (re包)
  10. Java任何一个元素都可以转换成String类型