初始化读取单个事件

问题描述

我有一个应用程序,可以在同一inotify fd上注册多个inotify手表。由于应用程序的结构方式,我需要将事件逐一读取(而不是单个read(2)可能返回多个事件),但是到目前为止,我还没有找到一种方法

最初,我尝试读取事件头struct inotify_event,然后根据.len字段读取事件的其余数据。但是如果提供的缓冲区太小,则在inotify fd上的read(2)将失败,并且EINVAL失败,如man page中所述:

 The behavior when the buffer given to read(2) is too small to return
 information about the next event depends on the kernel version: in
 kernels before 2.6.21,read(2) returns 0; since kernel 2.6.21,read(2) fails with the error EINVAL. 

从源头上看,read的实现将尝试返回尽可能多的事件,只要传递给它的缓冲区大小即可。可以here看到,如果成功复制了一个事件,它将继续循环,并尝试复制更多事件(如果存在)。

我还考虑了使用ioctl(FIONREAD)的可能性,但是它返回了所有排队事件的总大小,而不仅仅是一个事件(按预期……)

目前,我最好的选择是从read(...,sizeof(struct inotify_event))开始。如果使用EINVAL失败,请尝试read(...,sizeof(struct inotify_event) * 2 - 1),然后尝试sizeof(struct inotify_event) * 3 - 1,依此类推。这将是在不事先知道其大小的情况下实现读取单个事件的最少系统调用次数。显然,这不是最佳选择。

有没有更好的方法来实现单读?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...