[python] 파이썬에서 캐럿 연산자 (^)는 무엇을합니까?

나는 오늘 파이썬에서 캐럿 연산자를 발견하고 그것을 시도해 보았고 다음과 같은 출력을 얻었습니다.

>>> 8^3
11
>>> 8^4
12
>>> 8^1
9
>>> 8^0
8
>>> 7^1
6
>>> 7^2
5
>>> 7^7
0
>>> 7^8
15
>>> 9^1
8
>>> 16^1
17
>>> 15^1
14
>>>

8을 기반으로 한 것 같으므로 일종의 바이트 작업을 추측하고 있습니까? 수레에 대해 이상하게 작동하는 것 외에는이 검색 사이트에 대해 많이 찾을 수없는 것 같습니다.이 연산자가하는 일에 대한 링크가 있습니까? 아니면 여기서 설명 할 수 있습니까?



답변

비트 XOR (배타적 OR)입니다.

이 경우는 true로 결과를 사실 피연산자 (평가됩니다에)의 (단 하나).

시연하려면 :

>>> 0^0
0
>>> 1^1
0
>>> 1^0
1
>>> 0^1
1

자신의 예 중 하나를 설명하려면 :

>>> 8^3
11

다음과 같이 생각해보십시오.

1000 # 8 (이진)
0011 # 3 (이진)
---- # XOR 적용 ( '수직')
1011 # 결과 = 11 (이진)


답변

필요에 따라 개체 의 __xor__()또는 __rxor__()메서드를 호출합니다. 정수 형식의 경우 비트 배타적 or를 수행합니다.


답변

비트 단위 배타적 또는입니다. 바이너리 비트 연산자는 Python Language Reference의 5 장 에 설명되어 있습니다.


답변

일반적으로 기호 ^는 또는 메서드 의 중위 버전입니다 . 심볼의 오른쪽과 왼쪽에 배치되는 데이터 유형이 무엇이든이 기능을 호환 가능한 방식으로 구현해야합니다. 정수의 경우 일반적인 작업이지만 예를 들어 type with type 에 대한 함수의 기본 제공 정의가 없습니다 .__xor____rxor__XORfloatint

In [12]: 3 ^ 4
Out[12]: 7

In [13]: 3.3 ^ 4
---------------------------------------------------------------------------
TypeError                                 Traceback (most recent call last)
<ipython-input-13-858cc886783d> in <module>()
----> 1 3.3 ^ 4

TypeError: unsupported operand type(s) for ^: 'float' and 'int'

Python의 한 가지 멋진 점은 자신의 클래스에서이 동작을 재정의 할 수 있다는 것입니다. 예를 들어, 일부 언어에서 ^기호는 지수를 의미합니다. 한 예처럼 이렇게 할 수 있습니다.

class Foo(float):
    def __xor__(self, other):
        return self ** other

그렇다면이 같은 작동합니다, 지금, 의 인스턴스 Foo^기호는 지수를 의미합니다.

In [16]: x = Foo(3)

In [17]: x
Out[17]: 3.0

In [18]: x ^ 4
Out[18]: 81.0


답변

^연산자 를 사용하면 커튼 뒤에서 메서드 __xor__가 호출됩니다.

a^b와 동일합니다 a.__xor__(b).

또한, a ^= b동일하다 a = a.__ixor__(b)(단 __xor__때 대체로서 사용되는 __ixor__내재적 사용을 통해 호출 ^=되지만 존재하지 않음).

원칙적으로하는 __xor__일은 완전히 구현에 달려 있습니다. Python의 일반적인 사용 사례는 다음과 같습니다.

  • 세트의 대칭 차이 (모든 요소가 두 세트 중 정확히 하나에 있음)

데모:

>>> a = {1, 2, 3}
>>> b = {1, 4, 5}
>>> a^b
{2, 3, 4, 5}
>>> a.symmetric_difference(b)
{2, 3, 4, 5}
  • 두 정수의 비트에 대해 비트가 같지 않음

데모:

>>> a = 5
>>> b = 6
>>> a^b
3

설명:

    101 (5 decimal)
XOR 110 (6 decimal)
-------------------
    011 (3 decimal)


답변