Programming

배쉬 평등 연산자 (==, -eq)

procodes 2020. 8. 5. 21:35
반응형

배쉬 평등 연산자 (==, -eq)


누군가 가 bash 스크립팅 -eq의 차이점을 설명해 주 ==시겠습니까?

다음과 같은 차이점이 있습니까?

[ $a -eq $b ][ $a == $b ]

그것은 단순히 즉 ==변수가 숫자가 포함되어있는 경우에만 사용됩니다?


다른 방법 ==은 문자열 비교, -eq숫자 비교 입니다. -eq같은 가족이다 -lt, -le, -gt, -ge,와 -ne, 그건 당신이 어떤을 어떤 기억하는 데 도움합니다.

$ [ a == a ]; echo $?
0
$ [ a -eq a ]; echo $?
-bash: [: a: integer expression expected
2

==bash-ism입니다. POSIX 양식은 =입니다. 비 -bash 쉘로의 이식성이 중요한 경우을 사용하십시오 =.


==은 bash 특정 별명이며 =숫자 비교 대신 문자열 (어휘) 비교를 수행합니다. eq물론 숫자 비교입니다.

마지막으로, 나는 일반적으로 양식을 사용하는 것을 선호합니다 if [ "$a" == "$b" ]


연산자 주위의 테스트 구성 에 따라 다릅니다 . 옵션은 이중 괄호, 이중 괄호, 단일 괄호 또는 테스트입니다.

당신이 사용하는 경우 ((...)) , 당신은 산술 지분을 테스트하는 ==C에서와 같이 :

$ (( 1==1 )); echo $?
0
$ (( 1==2 )); echo $?
1

(참고 : 0수단 true유닉스 감각과 비 제로에 실패한 테스트입니다)

-eq이중 괄호 안에 사용하면 구문 오류가 발생합니다.

당신이 사용하는 경우 [...] (또는 단일 중괄호) 또는 [[...]] (또는 이중 중괄호), 또는 test, 당신은 -eq, -ne, -lt, -le, -gt 중 하나를 사용하거나 산술 비교 로 -ge .

$ [ 1 -eq 1 ]; echo $?
0
$ [ 1 -eq 2 ]; echo $?
1
$ test 1 -eq 1; echo $?
0

==단일 또는 이중 중괄호 (또는 test명령) 내부 문자열 비교 연산자 중 하나입니다 .

$ [[ "abc" == "abc" ]]; echo $?
0
$ [[ "abc" == "ABC" ]]; echo $?
1

문자열 연산자 는 공백 또는 필요한 공백과 =같습니다 .=====

당신은 동안 [[ 1 == 1 ]]또는 [[ $(( 1+1 )) == 2 ]]그 문자열 평등 시험하고있다 -하지 산술 평등을.

그래서 -eq결과 생산 아마 의 정수 값 것으로 예상 1+1IS가 동일 2RH 문자열과 뒤에 공간이 비록를 :

$ [[ $(( 1+1 )) -eq  "2 " ]]; echo $?
0

동일한 문자열 비교가 후미 공간을 차지하므로 문자열 비교가 실패합니다.

$ [[ $(( 1+1 )) ==  "2 " ]]; echo $?
1

그리고 잘못된 문자열 비교는 완전한 오답을 만들 수 있습니다. '10'는 사 전적으로 문자열 비교 반환 그래서, 이하 '2'가 아닌 true0. 많은 사람들 이이 버그에 물 렸습니다.

$ [[ 10 < 2 ]]; echo $?
0

10에 대한 올바른 테스트 대 산술적으로 2보다 작습니다.

$ [[ 10 -lt 2 ]]; echo $?
1

주석 에서 문자열에 정수 사용하는 기술적 이유에 대한 의문 -eq이 있습니다. 동일하지 않은 문자열에 대해서는 True를 반환합니다.

$ [[ "yes" -eq "no" ]]; echo $?
0

그 이유는 Bash가 형식화되지 않았기 때문 입니다. -eq문자열이 정수로 해석됩니다 가능하면 기본 변환을 포함 :

$ [[ "0x10" -eq 16 ]]; echo $?
0
$ [[ "010" -eq 8 ]]; echo $?
0
$ [[ "100" -eq 100 ]]; echo $?
0

그리고 0배쉬는 그냥 문자열입니다 생각하는 경우 :

$ [[ "yes" -eq 0 ]]; echo $?
0
$ [[ "yes" -eq 1 ]]; echo $?
1

그래서 [[ "yes" -eq "no" ]]동일합니다[[ 0 -eq 0 ]]

Last note: Many of the Bash specific extensions to the Test Constructs are not POSIX and therefore will fail in other shells. Other shells generally do not support [[...]] and ((...)) or ==.


Guys: Several answers show dangerous examples. OP's example [ $a == $b ] specifically used unquoted variable substitution (as of Oct '17 edit). For [...] that is safe for string equality.

But if you're going to enumerate alternatives like [[...]], you must inform also that the right-hand-side must be quoted. If not quoted, it is a pattern match! (From bash man page: "Any part of the pattern may be quoted to force it to be matched as a string.").

Here in bash, the two statements yielding "yes" are pattern matching, other three are string equality:

$ rht="A*"
$ lft="AB"
$ [ $lft = $rht ] && echo yes
$ [ $lft == $rht ] && echo yes
$ [[ $lft = $rht ]] && echo yes
yes
$ [[ $lft == $rht ]] && echo yes
yes
$ [[ $lft == "$rht" ]] && echo yes
$

참고URL : https://stackoverflow.com/questions/20449543/bash-equality-operators-eq

반응형