Страница википедии неверна, я исправил это. |
и &
не являются логическими операторами, даже если они являются нетерпеливыми операторами, что означает, что они не являются операторами короткого замыкания. Как вы, наверное, знаете, вот как работают операторы python and
и or
:
>>> def talk(x):
... print "Evaluating: ", bool(x)
... return x
...
>>> talk(1 == 1) or talk(2 == 1) # 2 == 1 is not evaluated
Evaluating: True
True
>>> talk(1 == 1) and talk(2 == 1)
Evaluating: True
Evaluating: False
False
>>> talk(1 == 2) and talk(1 == 3) # 1 == 3 is not evaluated
Evaluating: False
False
Насколько я знаю, в python нет активных логических операторов, их нужно было бы явно кодировать, например, так:
>>> def eager_or(a, b):
... return a or b
...
>>> eager_or(talk(1 == 1), talk(2 == 1))
Evaluating: True
Evaluating: False
True
Теперь a
и b
автоматически оцениваются при вызове функции, даже если or
по-прежнему короткое замыкание.
Что касается использования |
и &
, то при использовании с числами они являются бинарными операторами:
>>> bin(0b11110000 & 0b10101010)
'0b10100000'
>>> bin(0b11110000 | 0b10101010)
'0b11111010'
Скорее всего, вы будете использовать |
таким образом с привязками python к библиотекам, использующим флаги, например wxWidgets:
>>> frame = wx.Frame(title="My Frame", style=wx.MAXIMIZE | wx.STAY_ON_TOP)
>>> bin(wx.MAXIMIZE)
'0b10000000000000'
>>> bin(wx.STAY_ON_TOP)
'0b1000000000000000'
>>> bin(wx.MAXIMIZE | wx.STAY_ON_TOP)
'0b1010000000000000'
При использовании с наборами они выполняют операции пересечения и union соответственно:
>>> set("abcd") & set("cdef")
set(['c', 'd'])
>>> set("abcd") | set("cdef")
set(['a', 'c', 'b', 'e', 'd', 'f'])