我有一台计算机将一些传感器数据记录到8个不同的文件中。 我开发了一种软件,当您使用rj45电缆连接两台机器时,可以将这些数据复制到另一台计算机上。
在我的计算机上检索数据后,我需要使用伪序列(使用socat)逐行发送每个文件。
我创建了一个使用嵌套for循环的程序,以检查所有8个文件中的数据是否准备就绪,然后提取一行并将其发送到puttySX。
问题是CPU使用率。一种减少它的方法是使用阻塞函数来知道数据是否准备就绪,但是有没有像套接字或串口上的选择这样的功能但是这些文件?
如果不是,我该怎么办?谢谢
答案 0 :(得分:0)
您可以查看inotify,它可以监控文件系统事件。
以下是一个示例代码,供您入门(这不是生产代码):
#include <stdio.h>
#include <stdlib.h>
#include <sys/inotify.h>
#define BUF_LEN (sizeof(struct inotify_event) * 1)
int main(int argc, char *argv[])
{
char *filepath;
int fd, wd;
struct inotify_event *event;
char buf[BUF_LEN];
ssize_t ret;
if (argc != 2)
{
fprintf(stderr, "Usage: ./%s <filepath>\n", argv[0]);
return (EXIT_FAILURE);
}
filepath = argv[1];
/* Initialization */
fd = inotify_init();
if (fd == -1)
{
perror("inotify_init()");
return (EXIT_FAILURE);
}
/* Specify which file to monitor */
wd = inotify_add_watch(fd, filepath, IN_MODIFY);
if (wd == -1)
{
perror("inotify_add_watch");
close(fd);
return (EXIT_FAILURE);
}
/* Wait for that file to be modified, */
/* and print a notification each time it does */
for (;;)
{
ret = read(fd, buf, BUF_LEN);
if (ret < 1)
{
perror("read()");
close(fd);
return (EXIT_FAILURE);
}
event = (struct inotify_event *)buf;
if (event->mask & IN_MODIFY)
printf("File modified!\n");
}
close(fd);
return(EXIT_SUCCESS);
}
答案 1 :(得分:0)
所以,
我发帖回答我的问题。感谢@yoones我发现了一些技巧。
创建日志文件时,我在一个看起来像
的ini文件中将bool设置为true[CreatedFiles]
cli1=false
cli2=false
cli3=false
cli4=false
cli5=false
cli6=false
cli7=false
cli8=false
另一个程序使用inotify来检测相应文件中的创建和修改。一旦进行了一些更改,它就会读取ini文件,处理数据,当它完成读取数据时,它会删除日志文件并在相应行的ini文件中写入false。
由于我必须同时处理多个日志文件,每次读取一行时,我都会验证我的ini文件,看看是否还要开始处理另一个日志文件,以便我可以在同一时间。
我做了一个无限循环,所以当所有进程完成后,程序返回到select调用,等待一些更改而不消耗所有CPU的资源。
对不起,如果我不太清楚,英语不是我的母语。
感谢大家的回复和评论。