您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

python 3中的快速异或字节

python 3中的快速异或字节

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 2022/1/1 18:37:23 有246人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶