It's very simple. You just have to understand []
, [[]]
and (())
as completely different beasts.
[ expression ]
is just an invocation of a program [
(just a different name for test
) and takes the expression as arguments, just like for all command calls in bash. That means, you must use whitespace between arguments, especially after [
and before ]
, and keywords and special characters have to be escaped or quoted, and variables are expanded in the usual way.
Within the expression, -gt, -lt
and related are used for numerical comparison, while >, <
and the sort, are for string comparisons. Think of [
as nothing to do with bash, just calling a command that evaluates expressions and returns 0 (true) or non-zero (false), as all programs do.
Boolean operators &&
and ||
can't be used in there, because they get interpreted by bash and not passed to test
as arguments. -a
and -o
are used instead. But you can always do [ test1 ] && [ test2 ] || [ test3 ]
, which are 3 test invocations, combined by bash
's usual boolean operators (that is, if first fails, the second is skipped).
Note that bash
still comes with its own implementation of [
(builtin), but that doesn't change the way it's treated syntactically.
[[ ]]
and (( ))
are not builtin replacements for commands, but parts of a special syntax, so different rules apply. See man page for details on how variable names are wildcards are treated there. Boolean operators &&
and ||
have the usual meaning.
The [[ ]]
one is string-centered: all comparsions are for strings (but are more "modern", locale-aware than in [
, although test
could be platform-dependent). It handles also file tests, regex and so on.
The (( ))
is for arithmetic expressions. Variable names don't require $
there, and you can mostly just write mathematical expressions in there - that of course includes comparisons (which are numerical). Comparisons in this case are no different from any other arithmetic expression, true is 1, false is 0, and you can write stuff like (( x=y*(z>4) ))
. If used in a conditional expression, nonzero is true and zero is false. You can also capture the result as $(( ))
.
So:
[[ ]]
string conditionals, pattern matching and file tests
(( ))
arithmetic expressions and conditionals
[ ]
test command: handles both, special nonstandard syntax for boolean operators and comparison operators
Best Answer
Yes. Using the test from this answer:
So setting the variable to
""
is the same as setting it to empty value. Therefore, empty value and""
are the same.