目前我正在尝试解码数据(使用lua).我有的数据是64位十六进制(大端).
该特定数字需要转换为小端.除此之外,稍后将基于内部逻辑应用其他按位操作.
现在,最初我认为事情会很简单,记住我可以使用bitop并简单地应用我想要的任何按位操作.
现在,不幸的是,我(请注意我无法改变这一点),32位lua编译器,因此,我不能简单地使用这些操作.
我想问两个问题:
>如果我有十六进制
800A000000000000如何使用32位按位操作(特别是在这种情况下的操作,如上面共享的库中的bit.bswap,bit.rshift,bit.lshift)
十六进制数?可以将这个数字分成两部分,
然后对它们中的每一个应用操作然后合并它们
再度携手?如果是这样的话,怎么样?
>你有什么好的参考(如一本好书)我可以用来
熟悉算法,我能做什么,做什么
当我们谈论按位操作时(特别是
使用多个小块表示大量数字)
在提出这个问题之前,我发现并阅读了同一主题的其他参考文献,但所有这些都与具体案例有关(除非您熟悉该主题,否则很难理解):
> lua 64-bit transitioning issue
> Does Lua make use of
64-bit integers?
> Determine whether Lua compiler runs 32 or
64 bit
> Comparing signed 64 bit number using 32 bit bitwise
operations in Lua