一次c++监听Linux文件目录的实践

目的:监听系统/data/system/dropbox目录,解析出crash和ANR,并上传云端。

这里只记录如何监听这个目录和实践中遇到的问题。

使用的到技术:

1.inotify

2.epoll

3.thread

环境:android系统

demo测试:

1.通过UI按钮触发启动监听,观察监听过程日志;

2.通过UI按钮触发读取新增文件内容。

首先,利用linux系统接口inotify来监听该目录新增文件。

复制代码
inotify_fd = inotify_init();
复制代码
inotify_add_watch(inotify_fd, path.c_str(), IN_CREATE | IN_MODIFY | IN_DELETE) // 根据需要添加要监听的事件

然后,通过epoll监听

复制代码
// 创建epoll句柄
int epfd = epoll_create(256);
struct epoll_event ev;
ev.data.fd = inotify_fd;        
ev.events = EPOLLIN | EPOLLET;
// 注册 epoll 事件
LOGD("epoll_ctl");
epoll_ctl(epfd, EPOLL_CTL_ADD, inotify_fd, &ev);

// 循环监听事件

char buffer[BUF_LEN];

struct epoll_event events[20]; // 存储从内核得到的事件集合

while (!isStopped) {

LOGD("epoll wait");

// 等待事件发生。返回需要处理的事件数目

int nfds = epoll_wait(epfd, events, 20, 500);

LOGD("Event count: %d", nfds);

sleep(3);

// 遍历events

。。。

}

测试时,发现在监听过程中,点击读取文件内容,出现ANR,最后发现整个监听需要放到子线程完成

复制代码
work_thread = new std::thread([this, path] { startWatchImpl(path.c_str()); });
记得释放申请的内存和各种句柄
复制代码
close(epfd);
close(inotify_fd);
相关推荐
Kaede6几秒前
如何应对Linux云服务器磁盘空间不足的情况
linux·运维·服务器
Zfox_2 小时前
Redis:Hash数据类型
服务器·数据库·redis·缓存·微服务·哈希算法
Kookoos3 小时前
Dynamics 365 Finance + Power Automate 自动化凭证审核
运维·自动化·dynamics 365·power automate
apocelipes6 小时前
Linux c 运行时获取动态库所在路径
linux·c语言·linux编程
ABB自动化6 小时前
for AC500 PLCs 3ADR025003M9903的安全说明
服务器·安全·机器人
努力学习的小廉6 小时前
深入了解linux系统—— 进程池
linux·运维·服务器
秃头菜狗7 小时前
各个主要目录的功能 / Linux 常见指令
linux·运维·服务器
利刃大大7 小时前
【在线五子棋对战】二、websocket && 服务器搭建
服务器·c++·websocket·网络协议·项目
2301_793102497 小时前
Linux——MySql数据库
linux·数据库
vfvfb7 小时前
bat批量去掉本文件夹中的文件扩展名
服务器·windows·批处理·删除扩展名·bat技巧