python 移位运算

Maverick_yusheng 2014-12-06 07:08:42
最近工作中看到看到一段代码,不太了解,哪位大侠能够帮小弟解释一下。
def roundOfPower2(number):
t = number
t = t - 1
t = t | t >> 1
t = t | t >> 2
t = t | t >> 4
t = t | t >> 8
t = t | t >> 16
return t + 1

这个函数实在做什么我不太明白,如果number是0~2**16返回值大小与number相同,如果大于2**16~2**32返回值就会改变。(第一次在这里提问题,不太了解规矩,如果那里做的不对大家见谅,呵呵)
...全文
249 3 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
panghuhu250 2014-12-06
  • 打赏
  • 举报
回复
引用 楼主 u013760377 的回复:
最近工作中看到看到一段代码,不太了解,哪位大侠能够帮小弟解释一下。 def roundOfPower2(number): ... 这个函数实在做什么我不太明白,如果number是0~2**16返回值大小与number相同,如果大于2**16~2**32返回值就会改变。(第一次在这里提问题,不太了解规矩,如果那里做的不对大家见谅,呵呵)
看函数名, 再加上几个例子, 就能猜出来了.
Maverick_yusheng 2014-12-06
  • 打赏
  • 举报
回复
引用 1 楼 bugs2k 的回复:
将number向上取整到最接近的2的N次方,如number=25,那么返回32
原来如此,多谢大侠相助!我对位运算一直不太清楚,了解位运算要看些什么吗?
bugs2k 2014-12-06
  • 打赏
  • 举报
回复
将number向上取整到最接近的2的N次方,如number=25,那么返回32

37,743

社区成员

发帖
与我相关
我的任务
社区描述
JavaScript,VBScript,AngleScript,ActionScript,Shell,Perl,Ruby,Lua,Tcl,Scala,MaxScript 等脚本语言交流。
社区管理员
  • 脚本语言(Perl/Python)社区
  • WuKongSecurity@BOB
加入社区
  • 近7日
  • 近30日
  • 至今

试试用AI创作助手写篇文章吧