因为要将js的一个签名算法移植到python上,遇到一些麻烦。
int无限宽度,不会溢出
算法中需要用到了32位int的溢出来参与运算,但是python的int是不会溢出的,达到界限后会自己转为long,所以很麻烦。
#使用-342686650: ret = 123456789 << 20 print(ret) 得到结果129453825982464 print(bin(ret)) 这个二进制是11101011011110011010001010100000000000000000000 明显已经超出32位了 在JS上 document.writeln(123456789 << 20); 得到结果是-783286272 这就是溢出后截取的, 在python上想实现溢出效果,找到一个函数 #这个函数可以得到32位int溢出结果,因为python的int一旦超过宽度就会自动转为long,永远不会溢出,有的结果却需要溢出的int作为参数继续参与运算 def int_overflow(val): maxint = 2147483647 if not -maxint-1 <= val <= maxint: val = (val + (maxint + 1)) % (2 * (maxint + 1)) - maxint - 1 return val ret = int_overflow(123456789 << 20) print(ret) print(bin(ret)) 现在得到结果是-783286272 二进制:-101110101100000000000000000000
负数使用无符号右移>
在JS中,可以使用 a>b来实现无符号位移,python中没有这个运算符,只能自己实现了
无符号右移>,就是将有符号int a和b转为无符号uint后,再进行普通右移运算
比如-1的有符号int就是-1,无符号int就是4294967295
我们自己实现>可以这样
#无符号右移 import ctypes def unsigned_right_shitf(n,i): # 数字小于0,则转为32位无符号uint if n<0: n = ctypes.c_uint32(n).value # 正常位移位数是为正数,但是为了兼容js之类的,负数就右移变成左移好了 if i<0: return -int_overflow(n << abs(i)) #print(n) return int_overflow(n i) ret = unsigned_right_shitf(-1,20) print(ret)
结果等于4095
和JS上执行 -1 > 20 一样。
附赠sdbm hash算法的python实现
import ctypes # equ << def int_overflow(val): maxint = 2147483647 if not -maxint-1 <= val <= maxint: val = (val + (maxint + 1)) % (2 * (maxint + 1)) - maxint - 1 return val # equ > def unsigned_right_shitf(n,i): # 数字小于0,则转为32位无符号uint if n<0: n = ctypes.c_uint32(n).value # 正常位移位数是为正数,但是为了兼容js之类的,负数就右移变成左移好了 if i<0: return -int_overflow(n << abs(i)) #print(n) return int_overflow(n i) def hash_sdbm(string): hash = 0 for i in range(len(string)): hash = ord(string[i]) + (int_overflow(hash << 6)) + (int_overflow(hash << 16)) -hash val = unsigned_right_shitf(hash,0) return val a = hash_sdbm('hello') print(a) # result:684824882
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
标签:
python,移位操作
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“python的移位操作实现详解”评论...
更新动态
2024年11月25日
2024年11月25日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]