一次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);
相关推荐
HIT_Weston1 小时前
27、【Ubuntu】【远程开发】内网穿透:CA 签名
linux·运维·ubuntu
猫小呆2 小时前
Weaviate服务器部署笔记
服务器·weaviate
M158227690552 小时前
工业互联利器!EtherNet/IP 转 ModbusTCP 网关,让跨协议通信零门槛
服务器·网络·tcp/ip
阿巴~阿巴~2 小时前
基于UDP协议的英汉翻译服务系统:从网络通信到字典查询的完整机制
linux·服务器·网络·网络协议·udp协议·套接字绑定·英汉翻译服务系统
阿巴~阿巴~2 小时前
简易回声服务器实现与网络测试指南
linux·服务器·网络·udp协议·网络测试·udp套接字编程
凡间客5 小时前
Ansible安装与入门
linux·运维·ansible
君以思为故5 小时前
认识Linux -- 进程概念
linux·服务器
_OP_CHEN5 小时前
Linux网络编程:(八)GCC/G++ 编译器完全指南:从编译原理到实战优化,手把手教你玩转 C/C++ 编译
linux·运维·c++·编译和链接·gcc/g++·编译优化·静态链接与动态链接
阿乐艾官5 小时前
【十一、Linux管理网络安全】
linux·运维·web安全
weixin_537765806 小时前
【负载均衡】LVS DR模式详解
服务器·负载均衡·lvs