lua二进制操作函数

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

bit.ashr - 带符号的按位右移

  此函数需要两个整数作为参数。第一个参数可以带有符号,是被以为的数,第二个参数是一个无符号整数,是向右移动的位数。在以为过程中,第一个参数的符合始终会被保留。

  例如:

  print (bit.ashr (-1024, 6)) --> -16

bit.band - 按位“与”运算

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

  bit.band(a,b)即是a 和 b的按位与;

  例如:

  print (bit.band (18, 2)) --> 2

  print (bit.band (15, 7, 3)) --> 3

  print (bit.band (17, 10, 4)) --> 0

  bit.band(a,b,c)是a b c的互相按位与;

bit.bor - 按位“或”运算

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

  例如:

  print (bit.bor (1, 2, 8)) --> 11

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

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

  例如:

  print(bit.mod (17, 4))  --> 1

bit.neg - 按位“非”运算

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

  例如:

  print (bit.neg (1)) --> 4294967294

bit.shl - 按位左移

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

  例如:

  print (bit.shl (4, 6)) --> 256

bit.shr - 按位右移

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

  例如:

  print (bit.shr (1024, 6)) --> 16

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

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

  例如:

  print (bit.tostring (45035996273, 16)) -->  A7C5AC471

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

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

  例如:

  print (bit.tonumber ("A7C5AC471", 16)) -->  45035996273

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

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

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

bit.xor - 按位“异或”运算

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

  例如:

  print (bit.xor (15, 1)) --> 14

时间: 2024-08-05 23:11:53

lua二进制操作函数的相关文章

94二进制操作函数

#include<stdio.h>#include<stdlib.h>#include<string.h>void test_write() { FILE*write = fopen("sats.db", "wb"); if (!write) { printf("文件为空\n"); system("pause"); return; } int l_v1 = 0x10; int l_v2 =

C#二进制字节数组操作函数 截取字节数组SubByte

/// <summary> /// 截取字节数组 /// </summary> /// <param name="srcBytes">要截取的字节数组</param> /// <param name="startIndex">开始截取位置的索引</param> /// <param name="length">要截取的字节长度</param> ///

Lua程序设计 深入函数01

在Lua中,函数是一种"第一类值":表示在Lua中的函数与其他传统类型的值(例如:数字和字符串)是一样的,可以存储到变量(全局,局部均可)或table中,可以作为实参传递给其他函数,还可以作为其他函数的返回值. "词法域":指一个函数可以嵌套在另一个函数中,内部的函数可以访问外部函数中的变量. Lua中的函数与所有其他值一样都是匿名的,当讨论一个函数时,实际上是在讨论一个持有某函数的变量.这与变量持有各种值一个道理,可以以多种方式来操作这些变量. a = {p = 

自写字符串操作函数

[字符操作函数] 1.strstr()函数用来检索子串在字符串中首次出现的位置,其原型为:    char *strstr( const char *dest,const  char * src ); [参数说明]dest为要检索的字符串,src为要检索的子串. [返回值]返回字符串str中第一次出现子串src的地址:如果没有检索到子串,则返回NULL. [函数实现] #include <stdio.h> char* my_strstr(const char *dest,const char 

mysql常用字符串操作函数大全

测试表 CREATE TABLE `string_test` ( `id` int(11) NOT NULL auto_increment COMMENT '用户ID', `name` varchar(50) NOT NULL default '' COMMENT '名称', `job` varchar(23) NOT NULL COMMENT '工作', `sex` tinyint(1) NOT NULL default '1' COMMENT '性别', `hobby` varchar(10

总结文件操作函数(一)-C语言

在进程一开始运行,就自动打开了三个对应设备的文件,它们是标准输入.输出.错误流,分别用全局文件指针stdin.stdout.stderr表示,对应的文件描述符为0,1,2:stdin具有可读属性,缺省情况下是指从键盘的读取输入,stdout和stderr具有可写属性,缺省情况下是指向屏幕输出数据. 将文件路径转化为文件指针: #include <stdio.h>  //头文件包含 FILE *fopen(const char *pach,const char *mode);  //文件名  模

mysql常用字符串操作函数大全,以及实例

今天在论坛中看到一个关于mysql的问题,问题如下 good_id     cat_id12654         665,56912655         601,4722 goods_id是商品idcat_id是分类id当我,怎么根据这种分类ID查数据(一个商品有多个分类,而且用逗号隔开了)我现在用的是like 这样的话,输入一个分类id是688,或者4722都能出来这个商品,但输入一个722也出来这个商品了. 如果用like做的话,肯定会有问题的,我的开始的想法是,把cat_id里面的字符

unix文件操作函数

1. fopen函数 1 #include <stdio.h> 2 FILE *fopen(const char *path, const char *mode) 返回:文件顺利打开后,指向该流的文件就会被返回.如何文件打开失败则返回NULL,并把错误代码存在 errno 中. 参数说明: mode: 1)r        以只读方式打开文件,该文件必须存在.     2) r+     以可读写方式打开文件,该文件必须存在.    3) rb+   以读写打开一个二进制文件,允许读写数据,文

Lua中的函数

[前言] Lua中的函数和C++中的函数的含义是一致的,Lua中的函数格式如下: function MyFunc(param) -- Do something end 在调用函数时,也需要将对应的参数放在一对圆括号中,即使调用函数时没有参数,也必须写出一对空括号.对于这个规则只有一种特殊的例外情况:一个函数若只有一个参数,并且此参数是一个字符串或table构造式,那么圆括号便可以省略掉.看以下代码: print "Hello World" --> print("Hell