On 01/04/2018 18:55, Arkadiusz Bulski wrote:
What would be the most performance efficient way of checking if a bytes is
all zeros? Currently its `key == b'\x00' * len(key)` however, because its
Python 2/3 compatible:
That doesn't too efficient, if you first have to construct a compatible
object of all zeros.
sum(key) == 0 is invalid
key == bytes(len(key)) is invalid
I already considered precomputing the rhs value.
Length of key is unknown,
(So how can you precompute the table?)
could be few bytes, could be megabytes.
How likely would be a block of all zeros? Or one that is all zeros but
with a sparse smattering of non-zeros?
If not very, then just check the bytes one by one. If non-zero, you will
know as soon as you see the first non-zero byte, possibly the first one.
def allzeros(a):
for x in a:
if x: return 0
return 1
--
bartc
--
https://mail.python.org/mailman/listinfo/python-list