当我使用非零参数显式调用exit时,为什么我的Perl脚本返回零返回码?

我有一个调用另一个脚本的Perl脚本. Perl脚本应该传播脚本的返回代码,但似乎返回零到其调用者( Java应用程序)desipte显式调用退出$scriptReturnCode.

代码输出如下(我意识到< =>可能/应该是!=但这就是我所拥有的):

print "INFO: Calling ${scriptDirectory}/${script} ${args}"
$scriptReturnCode = system("${scriptDirectory}/${script} ${args}");

if ( $scriptReturnCode <=> 0 ) {
        print "ERROR: The script returned $scriptReturnCode\n";
        exit $scriptReturnCode;
} else {
        print "INFO: The script returned $scriptReturnCode.\n";
        exit 0;
}

我从Java获得的输出是:

20/04/2010 14:40:01 - INFO: Calling /path/to/script/script.ksh arg1 arg2 
20/04/2010 14:40:01 - Could not find installer files <= this is from the script.ksh    
20/04/2010 14:40:01 - ERROR: The script returned 256
20/04/2010 14:40:01 - Command Finished. Exit Code: 0 <= this is the Java app.

解决方法

您需要将系统()调用的返回码移位8位.

例如. $exit_value = $? >> 8; #在你的脚本中$?是$scriptReturnCode

http://perldoc.perl.org/perlfaq8.html开始:

system() runs a command and returns exit status information (as a 16 bit value: the low 7 bits are the signal the process died from,if any,and the high 8 bits are the actual exit value

更加扩展的代码检查coredump也可能如下所示:

system();
if ($? == -1) {
    print "Failed to execute: $!\n";
} elsif ($? & 127) {
    printf "child died - signal %d,%s coredump\n",($? & 127),($? & 128) ? 'with' : 'without';
} else {
    printf "child exited with value %d\n",$? >> 8;
}

更新:根据ysth的优秀提醒,退出代码被截断为8(低)位,因此返回256而不是预期的1最终为0.同样,返回257最终为1.

相关文章

忍不住在 PerlChina 邮件列表中盘点了一下 Perl 里的 Web 应用框架(巧的是 PerlBuzz 最近也有一篇相关...
bless有两个参数:对象的引用、类的名称。 类的名称是一个字符串,代表了类的类型信息,这是理解bless的...
gb2312转Utf的方法: use Encode; my $str = "中文"; $str_cnsoftware = encode("utf-8...
  perl 计算硬盘利用率, 以%来查看硬盘资源是否存在IO消耗cpu资源情况; 部份代码参考了iostat源码;...
1 简单变量 Perl 的 Hello World 是怎么写的呢?请看下面的程序: #!/usr/bin/perl print "Hello W...
本文介绍Perl的Perl的简单语法,包括基本输入输出、分支循环控制结构、函数、常用系统调用和文件操作,...