当打开n个管道到从Perl执行xargs的子进程时,n-1进程接收一个空行

laf*_*blu 5 perl pipe xargs

...另一方面,如果我在打开下一个管道之前写了一些东西,这不会发生.

以下代码应该更清楚:

sub test_concurrent_pipes
{
    my $write_at_once = $_[0];
    my $pipe_handle;
    my @pipe_handle_list;
    my $i;
    foreach $i ( 1..3 )
    {
        open ( $pipe_handle, "| xargs echo" ) or die ( "Cannot open pipe.\n" );
        if ( $write_at_once == 1 )
        {
          print $pipe_handle "Hello\n";
        }
        push( @pipe_handle_list, $pipe_handle );
    }
    foreach $pipe_handle ( @pipe_handle_list )
    {
        print $pipe_handle "world\n";
    }
    foreach $pipe_handle ( @pipe_handle_list )
    {
        close ( $pipe_handle );
    }
}

print "Test 0: open all pipes before writing\n";
test_concurrent_pipes(0);

print "Test 1: write Hello before opening next pipe\n";
test_concurrent_pipes(1);
Run Code Online (Sandbox Code Playgroud)

我得到了测试

./test_pipe_2_xargs.pl 
Test 0: open all pipes before writing


world world world
Test 1: write Hello before opening next pipe
Hello
Hello
Hello world world world
Run Code Online (Sandbox Code Playgroud)

正如您在测试0中看到的那样,连续打开3个管道而中间没有任何输出会生成2个空行.奇怪的是,如果我替换xargs echocat -有没有产生空行.xargs行为似乎也与其手册页相矛盾Blank lines on the standard input are ignored.

我该如何避免那些空行呢?

在cygwin/XP上使用Perl 5.14.2,在HP-UX 11.00上使用Perl 5.8.8.

我写了最后我真正想做的事情,因为它与此无关:

通过Perl脚本有效清理所有Clearcase视图中可见的所有派生对象,该脚本在从VOB(rmdo)中删除文件之前,每个视图分配一个进程以删除文件(xargs rm).

AnF*_*nFi 3

让“创建循环”使用局部变量 ( my $pipe_handle) 可以解决这个问题。

foreach $i ( 1..3 )
{
    open ( my $pipe_handle, "| xargs echo" ) or die ( "Cannot open pipe.\n" );
    ...
}
Run Code Online (Sandbox Code Playgroud)