一次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);
相关推荐
ITOWARE_SAPer3 小时前
选择SAP实施公司能否兼得官方授权与高性价比?
运维·能源·制造·零售
开压路机3 小时前
进程控制
linux·服务器
香蕉鼠片3 小时前
跨平台开发到底是什么
linux·windows·macos
Elastic 中国社区官方博客3 小时前
Elasticsearch:快速近似 ES|QL - 第一部分
大数据·运维·数据库·elasticsearch·搜索引擎·全文检索
2401_873479403 小时前
如何从零搭建私有化IP查询平台?数据采集、清洗、建库到API发布全流程
服务器·网络·tcp/ip
AC赳赳老秦4 小时前
OpenClaw生成博客封面图+标题,适配CSDN视觉搜索,提升点击量
运维·人工智能·python·自动化·php·deepseek·openclaw
Eric.Lee20214 小时前
docker 启动停止命令
运维·docker·容器
samson_www5 小时前
EC2的GRUB引导程序问题
运维·ai
bukeyiwanshui5 小时前
20260417 DNS实验
linux
代码中介商5 小时前
Linux 帮助手册与用户管理完全指南
linux·运维·服务器