perl – 为什么我的父进程在退出之前看不到子进程的输出?

前端之家收集整理的这篇文章主要介绍了perl – 为什么我的父进程在退出之前看不到子进程的输出?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
请考虑以下脚本:
use IO::File;
$| = 1;
my ($handle,$pid) = myPipe();
if ($pid == 0) {
  print "$$";
  sleep 5;
  exit;
}

print "child: ".<$handle>."\n";

sub myPipe {
  my $handle = new IO::File();
  my $pid = open($handle,"-|");
  return ($handle,$pid);
}

在这种情况下,进程启动后5秒内不会出现“child:”消息.如果我从分叉的孩子中删除睡眠呼叫,则立即打印.为什么分叉的孩子必须退出管道以冲洗父母?

解决方法

有两个问题.首先,子进程正在缓冲其输出;第二,父进程正在使用<>运算符,它阻塞直到完整的行可用,或直到文件结束.

因此,获得您期望的结果的一种方法是让子进程在写入后立即关闭输出流:

if ($pid == 0) {
    print "$$";
    close STDOUT;
    sleep 5;
    exit;
}

另一种方法是在子进程的输出添加换行符,然后刷新流:

if ($pid == 0) {
    print "$$\n";
    STDOUT->flush;  # "close STDOUT;" will work too,of course
    sleep 5;
    exit;
}

刷新是必要的,因为管道(通常)是无缓冲的,而不是通常作为连接到终端的流进行行缓冲.

第三种方法是将子进程的输出流设置为autoflush:

if ($pid == 0) {
    $| = 1;
    print "$$\n";
    sleep 5;
    exit;
}

猜你在找的Perl相关文章