java – Shebang行解析Ubuntu中的问题

什么是在shebang线中包含解释器选项的可接受的,可移植的方式,即.我该怎么办呢

#!/usr/bin/env  python -c 

或者(更重要的是)类似的东西

#!/usr/bin/env java -cp "./jars/*:./src" -Xmn1G -xms1G -server

并让它正确解析?现在ubuntu似乎只是将整个事情放在一起,尽管其他系统会解析这个问题没有问题.

http://en.wikipedia.org/wiki/Shebang_%28Unix%29

描述了问题,但没有解决方案.

最佳答案
没有好的解决方案,因为不同的unices对待多字#!线条不同.便携#!使用限制你最多只有一个参数解释#! line,并且在解释器或参数中没有空格.

如果语言允许,您可以将脚本设置为shell脚本,该脚本负责使用它喜欢的任何命令行加载解释器.例如,在Perl中,来自perl手册:

#!/bin/sh -- # -*- perl -*- -p
eval 'exec perl -wS "$0" ${1+"$@"}'
if $running_under_some_shell;

shell在第二行之后停止处理,并且Perl将第2-3行视为不执行任何操作的指令.一些lisp / scheme方言使#!……!#一个注释,允许你写

#!/bin/sh
exec guile -s "$0" "$@"
!# ;; scheme code starts here

通常,唯一的解决方案涉及两个文件.您可以编写#!/usr/bin/env mywrapper,其中mywrapper是一个程序(它可以是一个脚本),可以使用它想要的任何参数调用实际的解释器.或者,您可以将可执行文件本身设置为包装器脚本,并将解释的文件保持独立.第二种解决方案具有工作的优势,即使解释器不接受领先的#!线.

相关文章

最近看了一下学习资料,感觉进制转换其实还是挺有意思的,尤...
/*HashSet 基本操作 * --set:元素是无序的,存入和取出顺序不...
/*list 基本操作 * * List a=new List(); * 增 * a.add(inde...
/* * 内部类 * */ 1 class OutClass{ 2 //定义外部类的成员变...
集合的操作Iterator、Collection、Set和HashSet关系Iterator...
接口中常量的修饰关键字:public,static,final(常量)函数...