uint8_t Python 翻车?最好或最优雅的方式是什么?
uint8_t rollover in Python? What is the best or most elegant way?
在 C 中,我可以执行以下操作:
uint8_t number;
number++;
注意:如果数字大于 255,则滚动到 0。
我该怎么做Python?
number += 1
if number>255:
number = 0
这对我来说不是最佳的或 Pythonic 的方式。
有什么想法吗?
Python 提供 arbitrary sized integers。有一种整数类型可以容纳mod任何大小的整数。
递增后使用mod256可以避免if语句。
number = (number + 1) % 256
您可以为此使用 ctypes
模块,它提供了 c 中存在的数据类型。
from ctypes import *
a=c_uint8(255)
b=c_uint(1)
c=c_uint8(a.value + b.value)
print(a, b, c)
输出
(c_ubyte(255), c_ulong(1L), c_ubyte(0))
您可以自由地进行所有标准数学运算,只要您需要字节范围内的输出,只需使用 number % 256
而不是 number
。或者您可以将此方法扩展到 class 并在其中定义所有标准运算符(__add__()
、__neg__()
、...)。或者您可以使用 ctypes 模块中的 c_ubyte
数据类型。
在 C 中,我可以执行以下操作:
uint8_t number;
number++;
注意:如果数字大于 255,则滚动到 0。
我该怎么做Python?
number += 1
if number>255:
number = 0
这对我来说不是最佳的或 Pythonic 的方式。 有什么想法吗?
Python 提供 arbitrary sized integers。有一种整数类型可以容纳mod任何大小的整数。
递增后使用mod256可以避免if语句。
number = (number + 1) % 256
您可以为此使用 ctypes
模块,它提供了 c 中存在的数据类型。
from ctypes import *
a=c_uint8(255)
b=c_uint(1)
c=c_uint8(a.value + b.value)
print(a, b, c)
输出
(c_ubyte(255), c_ulong(1L), c_ubyte(0))
您可以自由地进行所有标准数学运算,只要您需要字节范围内的输出,只需使用 number % 256
而不是 number
。或者您可以将此方法扩展到 class 并在其中定义所有标准运算符(__add__()
、__neg__()
、...)。或者您可以使用 ctypes 模块中的 c_ubyte
数据类型。