当
bytes对每个具有一百万个元素的对象进行XOR运算时,此循环将创建大约一百万个临时
bytes对象,并将 每个 字节平均从一个临时对象复制到下
一个
字节大约50万次
bytes。请注意,字符串存在完全相同的问题(也存在许多其他语言)。弦乐解决方案是创建弦乐部件列表,并
''.join在最后使用它来有效地连接它们。您可以对字节执行相同的操作:
def bxor(b1, b2): # use xor for bytes parts = [] for b1, b2 in zip(b1, b2): parts.append(bytes([b1 ^ b2])) return b''.join(parts)
或者,您可以使用
bytearray可变的a ,因此可以避免此问题。它还允许您不必
bytes在每次迭代中分配新对象,您只需追加byte
/即可
int。
def bxor(b1, b2): # use xor for bytes result = bytearray() for b1, b2 in zip(b1, b2): result.append(b1 ^ b2) return result
return bytes(result)如果您想要/需要一个
bytes对象,也可以选择。


![python 3中的快速异或字节[重复] python 3中的快速异或字节[重复]](http://www.mshxw.com/aiimages/31/659824.png)
