这篇文章主要介绍了shell脚本编程在UNIX和Linux下有什么区别,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
与其他 UNIX 操作系统和 Linux 一样,IBM? AIX? 操作系统提供了几种能够帮助系统管理员、开发人员和用户执行日常任务的强大工具,使他们或其客户的工作更轻松。在 UNIX 中,这些工具之一能够通过编写 shell 脚本编程来自动执行任务,从而简化那些困难、漫长或繁琐的工作。
尽管在近两年使用过 UNIX 的一些人可能尝试过 shell 脚本编程,但是他们很可能只是研究操作系统的细节,并不精通 shell 脚本编程。本文针对那些希望进一步了解 shell 脚本编程,并开始编写更高级脚本的读者。本文提供脚本编程的基础知识,包括如何简化脚本、如何尽可能保持脚本的灵活性、如何编写干净的脚本、在脚本内编写注释以及调试脚本。
shell 脚本编程保持简单
在人们学习如何编写 shell 脚本编程时,常常遇到的一个问题是,重复他们在另一个脚本中已经做过的工作。他们其实不需要复制原来的脚本并修改几个硬编码值,只需创建一个函数来处理两个脚本的重复部分。创建集中的函数还可以促进标准化,帮助创建统一的脚本。如果一个函数在脚本的一个部分工作正常,那么它在脚本中的其他地方也会正常工作。
例如,清单 1 所示的脚本应该浓缩和简化为更简单、更干净的程序。
清单 1. 可以简化的脚本示例
#!/usr/bin/ksh if [[ $# -lt 2 ]] then echo "Usage: ${0##*/} <file name #1> <file name #2> exit 0 fi if [[ ! -f "${1}" ]] then echo "Unable to find file '${1}'" exit 1 fi if [[ ! -r "${1}" ]] then echo "Unable to read file '${1}'" exit 2 fi gzip ${1} ls -l ${1}.gz if [[ ! -f "${2}" ]] then echo "Unable to find file '${2}'" exit 1 fi if [[ ! -r "${2}" ]] then echo "Unable to read file '${2}'" exit 2 fi gzip ${2} ls -l ${2}.gz
这个脚本看起来很糟糕!(谢天谢地,它只是一个示例)。这个shell 脚本编程应该尽可能进行浓缩。从便于阅读的角度来看,清单 2 提供的版本更干净。
清单 2. 对清单 1 脚本进行浓缩的版本
#!/usr/bin/ksh exit_msg() { [[ $# -gt 1 ]] && echo "${0##*/} (${1}) - ${2}" exit ${1:-0} } [[ $# -lt 2 ]] && exit_msg 0 "Usage: ${0##*/} <file name #1> <file name #2> for _FNAME in $@ do [[ ! -f "${_FNAME}" ]] && exit_msg 1 "Unable to find file '${_FNAME}'" [[ ! -r "${_FNAME}" ]] && exit_msg 2 "Unable to read file '${_FNAME}'" gzip ${_FNAME} ls -l ${_FNAME}.gz done
注意到这两者的差异了吗?这个shell 脚本编程增加了一个简单的函数来显示一个消息并带适当的返回码退出,还把所有操作转移到一个 for 循环中,这使这个脚本看起来更干净、更容易理解了。
感谢你能够认真阅读完这篇文章,希望小编分享的“shell脚本编程在UNIX和Linux下有什么区别”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。