lua 二进制的移位运算

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了lua 二进制的移位运算相关的知识,希望对你有一定的参考价值。

参考技术A 由于 Lua 脚本语言本身不支持对数字的二进制操作(例如 与,或,非 等操作),MUSHclient 为此提供了一套专门用于二进制操作的函数,它们都定义在一个“bit”表中,使用时只要requre “bit”即可。
  例如:

bit.bor - 按位“或”运算
  此函数需要一个或多个无符号整数作为参数,返回所有参数执行按位“或”运算后的结果。

例如:

bit.mod - 取模函数 (得到整除后的余数)

此函数需要两个整数作为参数。函数结果是两个数整除之后的余数。

例如:

bit.neg - 按位“非”运算
  此函数需要一个无符号整数作为参数,返回这个参数执行按位“非”运算后的结果。

例如:

bit.shl - 按位左移
  此函数需要两个无符号整数作为参数。第一个参数是被移位的数,第二个参数是向左移动的位数。

例如:

bit.shr - 按位右移
  此函数需要两个无符号整数作为参数。第一个参数是被移位的数,第二个参数是向右移动的位数。

例如:

bit.tostring (n, base) - 把一个数字转换为字符串

把一个数字根据指定的基数转换为字符串(大写形式)base 产生是可选的,默认为 10,其有效范围为 2 - 36。数字的小数部分会被忽略. 被转换的数字可以是负数,转换后会保留 "-" 符号。

例如:

bit.tonumber (s, base) - 把字符串转换为一个数字

把一个字符串形式的数字转换为相应的数字。和标准 Lua tonumber 函数不一样的是此函数可以处理高达 52 bit 的数字(Lua 默认的函数只能处理 32 bit 的数字)。

例如:

base 参数是可选的,指明了转换的基数,默认为 10。base 的有效范围是 2 - 36。此函数不支持小数,也不支持指数表示形式的整数(例如 10.24e15)。如果一定要使用这样的数,你只有使用 Lua 自带的 tonumber 函数了。

由于计算机对浮点数的限制,字符串能转换的数字不能超过 52 bit,例如:十六进制 FFFFFFFFFFFFF (十进制 4503599627370495)。

字符串开始的空白字符会自动被忽略,实际数字前面可以有一个 + 或者 - 号。

bit.xor - 按位“异或”运算
  此函数需要一个或多个无符号整数作为参数,返回所有参数执行按位“异或”运算后的结果。

例如:

以上是关于lua 二进制的移位运算的主要内容,如果未能解决你的问题,请参考以下文章

Java移位运算之算术右移位

常见的关系运算符(移位运算符)

c语言中的移位运算符

java移位运算

Java移位运算之算术左移位

移位运算符的效果