问题描述
在 C 中,我可以执行以下操作:
uint8_t number;
number++;
注意:如果数字大于 255,则转为 0。
我该怎么做 Python?
number += 1
if number>255:
number = 0
这对我来说不是最佳的或 Pythonic 的方式。 有什么想法吗?
解决方法
Python 提供了 arbitrary sized integers。有一种整数类型可以容纳任意大小的整数。
您可以通过在增量后使用 mod 256 来避免 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
。或者您可以将此方法扩展到一个类并在那里定义所有标准运算符(__add__()
、__neg__()
、...)。或者您可以使用 ctypes 模块中的 c_ubyte
数据类型。