测试 inotify 中 IN_DELETE_SELF

这篇博客探讨了在使用inotify时遇到的IN_DELETE_SELF事件问题。作者之前认为在该事件中,event结构的name属性无法printf,但经过测试发现是自己的代码存在问题,测试结果表明一切正常。
摘要由CSDN通过智能技术生成

// 这篇文章对 IN_DELETE_SELF的理解出错.

前段时间写 inotify 相关的程序, 发现当时间为 IN_DELETE_SELF或 IN_MOVE_SELF 时 event 结构中 name 属性不能 printf.

我觉得不应该, 今天特意写代码测试下.

#include <stdio.h>
#include <sys/inotify.h>
#include <unistd.h>
#include <stdlib.h>

#define BUF_LEN 1024
#define EVENT_NUM 12

static char *event_str[EVENT_NUM] = 
{
	"IN_ACCESS",
	"IN_MODIFY",
	"IN_ATTRIB",
	"IN_CLOSE_WRITE",
	"IN_CLOSE_NOWRITE",
	"IN_OPEN",
	"IN_MOVED_FROM",
	"IN_MOVED_TO",
	"IN_CREATE",
	"IN_DELETE",
	"IN_DELETE_SELF",
	"IN_MOVE_SELF"
};

int main(int argc, char *argv[])
{
	pid_t pid;
	
	if(argc < 2)
	{
		printf("%s dir\n", argv[0]);
		return -1;
	}
	
	pid = fork();
	if(pid == 0)
	{
		sleep(20);
		remove(argv[0]);
		exit(-1);
	}
	else if(pid < 0)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值