所以我在bash上运行它:
# somedevice -getevent
该命令的作用是一直保持运行状态,并且每当我的设备发送某个数据时,例如说它检测到温度变化,它就会输出类似的内容
/dev/xyz: 123 4567 8910112238 20 /dev/xyz: 123 4567 8915712347 19 /dev/xyz: 123 4567 8916412345 22 /dev/xyz: 123 4567 8910312342 25 /dev/xyz: 123 4567 8910112361 18 /dev/xyz: 123 4567 8910112343 20
而且这只会继续运行,并且一旦有任何原因就会输出一些东西。因此,执行无止境。
没有回声运行完美,但是当我尝试使用’>’运算符时,这似乎没有写入文件。
例如
#somedevice -getevent > my_record_file
这不能正常工作,my_record_file只获取 间隔 写入的数据,但是我想立即写入。
有任何想法吗?
因为C标准库根据stdout是否是终端设备来更改输出缓冲模式,所以正在缓冲输出。如果是终端设备(根据isatty(3)),则stdout是 行缓冲的 :每次写入换行符时,它将被刷新。如果它不是终端设备,那么它将被 完全缓冲 :仅在写入一定数量的数据(通常为4 KB到64 KB左右)时才刷新它。
isatty(3)
因此,当您使用Shell的>重定向操作符将命令的输出重定向到文件时,它不再输出到终端,并且会缓冲其输出。程序可以与setvbuf(3)和朋友更改其缓冲模式,但是该程序必须配合执行此操作。许多程序都有命令行选项来使它们行缓冲,例如grep(1)的--line- buffered选项。查看您的命令是否具有类似的选项。
>
setvbuf(3)
grep(1)
--line- buffered
如果没有这样的选项,则可以尝试使用诸如unbuffer(1)缓冲输出流之类的工具,但是它并不总是有效,也不是标准实用程序,因此它并不总是可用。
unbuffer(1)