Краткое имя | Полное имя | Описание |
---|---|---|
-C | noclobber | Предотвращает перезапись файла в операциях перенаправления вывода (не распространяется на конвейеры (каналы) -- >|) |
-D | (нет) | Выводит список строк в двойных кавычках, которым предшествует символ $, сам сценарий не исполняется |
-a | allexport | Экспорт всех, определенных в сценарии, переменных |
-b | notify | Выводит уведомление по завершении фоновой задачи (job) (довольно редко используется в сценариях) |
-c ... | (нет) | Читает команды из ... |
-f | noglob | Подстановка имен файлов (globbing) запрещена |
-i | interactive | Сценарий запускается в |
-p | privileged | Сценарий запускается как "suid" (осторожно!) |
-r | restricted | Сценарий запускается в |
-u | nounset | При попытке обращения к неопределенным переменным, выдает сообщение об ошибке и прерывает работу сценария |
-v | verbose | Выводит на stdout каждую команду прежде, чем она будет исполнена |
-x | xtrace | Подобна -v, но выполняет подстановку команд |
-e | errexit | Прерывает работу сценария при появлении первой же ошибки (когда команда возвращает ненулевой код завершения) |
-n | noexec | Читает команды из сценария, но не исполняет их (проверка синтаксиса) |
-s | stdin | Читает команды с устройства stdin |
-t | (нет) | Выход после исполнения первой команды |
- | (нет) | Конец списка ключей (опций), последующие аргументы будут восприниматься как позиционные параметры. |
-- | (нет) | Эквивалент предыдущей опции (-). |
Глава 31. Широко распространенные ошибки
Использование зарезервированных слов и служебных символов в качестве имен переменных.
case=value0 # Может вызвать проблемы.
23skidoo=value1 # Тоже самое.
# Имена переменных, начинающиеся с цифр, зарезервированы командной оболочкой.
# Если имя переменной начинается с символа подчеркивания: _23skidoo=value1, то это не считается ошибкой.
# Однако... если имя переменной состоит из единственного символа подчеркивания, то это ошибка.
_=25
echo $_ # $_ -- это внутренняя переменная.
xyz((!*=value2 # Вызывает серьезные проблемы.
Использование дефиса, и других зарезервированных символов, в именах переменных.
var-1=23
# Вместо такой записи используйте 'var_1'.
Использование одинаковых имен для переменных и функций. Это делает сценарий трудным для понимания.
do_something ()
{
echo "Эта функция должна что-нибудь сделать с \"$1\"."
}
do_something=do_something
do_something do_something
# Все это будет работать правильно, но слишком уж запутанно.
Использование лишних пробелов. В отличие от других языков программирования, Bash весьма привередлив по отношению к пробелам.
var1 = 23 # Правильный вариант: 'var1=23'.
# В вышеприведенной строке Bash будет трактовать "var1" как имя команды
# с аргументами "=" и "23".
let c = $a - $b # Правильный вариант: 'let c=$a-$b' или 'let "c = $a - $b"'
if [ $a -le 5] # Правильный вариант: if [ $a -le 5 ]
# if [ "$a" -le 5 ] еще лучше.
# [[ $a -le 5 ]] тоже верно.
Ошибочным является предположение о том, что неинициализированные переменные содержат "ноль". Неинициализированные переменные содержат "пустое" (null) значение, а
#!/bin/bash
echo "uninitialized_var = $uninitialized_var"
# uninitialized_var =
Часто программисты путают операторы сравнения
if [ "$a" = 273 ] # Как вы полагаете? $a -- это целое число или строка?
if [ "$a" -eq 273 ] # Если $a -- целое число.
# Иногда, такого рода ошибка никак себя не проявляет.
# Однако...
a=273.0 # Не целое число.