问题描述
|
我需要grep第三方程序的输出。该程序将转储数据,但在不按^ c终止数据之前不会终止数据。
我目前正在使用其pid搜索并杀死它。但是,我想知道是否可以回显控制C字符。伪代码看起来像
echo ^c | ./program_that_does_not_terminate
我可以在DOS中执行类似的操作,因此在Linux中必须有一种方法。
C:\\>echo y | del C:\\tmp\\*
C:\\tmp\\*,Are you sure (Y/N)? y
C:\\>
解决方法
否,将CTRL-C字符传送到您的进程中将不起作用,因为终端会捕获CTRL-C按键并将其转换为发送给进程的终止信号。
CTRL-C的正确字符代码(ASCII)是代码号3,但是,如果将其回显到程序,它将仅从其标准输入中接收字符。它不会导致进程终止。
如果您想简化查找和终止进程的任务,则可以使用以下方法:
./program_that_does_not_terminate &
pid=$!
sleep 20
kill ${pid}
$!
将为您提供上一次启动的后台进程的进程ID。
, 在Bash中,可以通过写$\'\\cc\'
在命令行上将^C
作为自变量传递(并因此传递给echo
进行回显)。因此,所需的命令是:
回声$ \'\\ cc \'| ./program_that_does_not_terminate
, 请尝试以下操作:
expect -c \"send \\003;\"
, 我认为,您将需要在这里进行一些更复杂的操作。如果要捕获程序的输出,则不能立即将终止信号发送到程序。与上面的示例相比,del
命令等待输入,而CTRL + C不是直接输入,而是停止信号。
我建议一个解决方案,在此您可以确定是否捕获了所有输出,然后发送终止信号。但是,所有输出只能由您确定的时间点。
, 正如@paxdiablo所说,CTRL-C按键被终端捕获,并转换为发送给进程的终止信号。因此,如果您的进程连接到终端,则可以将@jwodder提供的$ \'\\ cc \'发送到该终端,让终端向该进程发送实际的终止信号。
步:
1.编译C文件中的通过/ dev / pts在另一个终端中执行命令
2.sudo ./a.out -n /dev/pts/0 $\'\\cc\'
#将/ dev / pts / 0更改为您的进程所连接的tty