在shell脚本的开头往往有一句话来定义使用哪种sh解释器来解释脚本。
目前研发送测的shell脚本中主要有以下两种方式:
(1) #!/bin/sh
(2) #!/bin/bash
以上两种方式有什么区别?对于脚本的实际运行会产生什么不同的影响吗?

脚本test.sh内容:
#!/bin/sh
source pcy.sh #pcy.sh并不存在
echo hello
执行./test.sh,屏幕输出为:
./test.sh: line 2: pcy.sh: No such file or directory
由此可见,在#!/bin/sh的情况下,source不成功,不会运行source后面的代码。
修改test.sh脚本的第一行,变为#!/bin/bash,再次执行./test.sh,屏幕输出为:
./test.sh: line 2: pcy.sh: No such file or directory
hello
由此可见,在#!/bin/bash的情况下,虽然source不成功,但是还是运行了source后面的echo语句。
但是紧接着我又试着运行了一下sh ./test.sh,这次屏幕输出为:
./test.sh: line 2: pcy.sh: No such file or directory
表示虽然脚本中指定了#!/bin/bash,但是如果使用sh 方式运行,如果source不成功,也不会运行source后面的代码。

为什么会有这样的区别呢?

说明:

1. sh一般设成bash的软链
[work@zjm-testing-app46 cy]$ ll /bin/sh
lrwxrwxrwx 1 root     root          4 Nov 13   2006 /bin/sh -> bash
2. 在一般的linux系统当中(如redhat),使用sh调用执行脚本相当于打开了bash的POSIX标准模式
3. 也就是说 /bin/sh 相当于 /bin/bash --posix

所以,sh跟bash的区别,实际上就是bash有没有开启posix模式的区别

so,可以预想的是,如果第一行写成 #!/bin/bash --posix,那么脚本执行效果跟#!/bin/sh是一样的(遵循posix的特定规范,有可能就包括这样的规范:“当某行代码出错时,不继续往下解释”)

[原文]http://meiling.blog.51cto.com/6220221/1826201

最新文章

  1. JFinal 的初始化
  2. GCC编译器编译链接
  3. hdu 1284 钱币兑换问题(动态规划)
  4. 关于匿名类无法转换为object
  5. android 引入phonegap
  6. 剑指Offer:面试题16——反转链表(java实现)
  7. partial函数-python学习
  8. [置顶] JNI之java传递数据给c语言
  9. 【学习总结】GirlsInAI ML-diary day-14-function函数
  10. Alpha冲刺
  11. springboot 02-PropertiesFile 自定义配置属性,多环境配置
  12. [转] JavaScript设计模式之发布-订阅模式(观察者模式)-Part1
  13. 16.4-uC/OS-III同步 (任务信号量)
  14. Hadoop---集群的时间同步
  15. 关于xp操作系统下使用VC6++编写的上位机软件在win10中运行的问题
  16. liunx trac 邮件提示功能
  17. 开源的挖矿软件,sha256
  18. .Net socket服务器编程之为何也高效
  19. DataTable List 相互转换
  20. IP地址工具类

热门文章

  1. POJ1475 Pushing Boxes(双搜索)
  2. loj #6570. 毛毛虫计数
  3. es去重查询
  4. python 简单爬虫(beatifulsoup)
  5. vue Vue-cli 笔记
  6. 关闭tensorflow运行时的警告信息
  7. head first
  8. Python之人工智能(一)
  9. KB4284826 远程桌面发生身份验证错误,要求的函数不受支持
  10. readonly与disable