![python 3中的快速异或字节[重复],第1张 python 3中的快速异或字节[重复],第1张](/aiimages/python+3%E4%B8%AD%E7%9A%84%E5%BF%AB%E9%80%9F%E5%BC%82%E6%88%96%E5%AD%97%E8%8A%82%5B%E9%87%8D%E5%A4%8D%5D.png)
当
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对象,也可以选择。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)