lua中位運算操作

2021-06-09 07:33:13 字數 3114 閱讀 6252

--[[

description:

filename:bit.lua

this module provides a selection of bitwise operations.

history:

initial version created by 陣雨 2005-11-10.

notes:

....

]]--[[

]]bit=}

for i=1,32 do

bit.data32[i]=2^(32-i)

endfunction bit:d2b(arg)

local tr={}

for i=1,32 do

if arg >= self.data32[i] then

tr[i]=1

arg=arg-self.data32[i]

else

tr[i]=0

endend

return tr

end --bit:d2b

function bit:b2d(arg)

local nr=0

for i=1,32 do

if arg[i] ==1 then

nr=nr+2^(32-i)

endend

return nr

end --bit:b2d

function bit:_xor(a,b)

local op1=self:d2b(a)

local op2=self:d2b(b)

local r={}

for i=1,32 do

if op1[i]==op2[i] then

r[i]=0

else

r[i]=1

endend

return self:b2d(r)

end --bit:xor

function bit:_and(a,b)

local op1=self:d2b(a)

local op2=self:d2b(b)

local r={}

for i=1,32 do

if op1[i]==1 and op2[i]==1 then

r[i]=1

else

r[i]=0

endend

return self:b2d(r)

end --bit:_and

function bit:_or(a,b)

local op1=self:d2b(a)

local op2=self:d2b(b)

local r={}

for i=1,32 do

if op1[i]==1 or op2[i]==1 then

r[i]=1

else

r[i]=0

endend

return self:b2d(r)

end --bit:_or

function bit:_not(a)

local op1=self:d2b(a)

local r={}

for i=1,32 do

if op1[i]==1 then

r[i]=0

else

r[i]=1

endend

return self:b2d(r)

end --bit:_not

function bit:_rshift(a,n)

local op1=self:d2b(a)

local r=self:d2b(0)

if n < 32 and n > 0 then

for i=1,n do

for i=31,1,-1 do

op1[i+1]=op1[i]

endop1[1]=0

endr=op1

endreturn self:b2d(r)

end --bit:_rshift

function bit:_lshift(a,n)

local op1=self:d2b(a)

local r=self:d2b(0)

if n < 32 and n > 0 then

for i=1,n do

for i=1,31 do

op1[i]=op1[i+1]

endop1[32]=0

endr=op1

endreturn self:b2d(r)

end --bit:_lshift

function bit:print(ta)

local sr=""

for i=1,32 do

sr=sr..ta[i]

endprint(sr)

endbs=bit:d2b(7)

bit:print(bs)

-->00000000000000000000000000000111

bit:print(bit:d2b(bit:_not(7)))

-->11111111111111111111111111111000

bit:print(bit:d2b(bit:_rshift(7,2)))

-->00000000000000000000000000000001

bit:print(bit:d2b(bit:_lshift(7,2)))

-->00000000000000000000000000011100

print(bit:b2d(bs)) --> 7

print(bit:_xor(7,2)) --> 5

print(bit:_and(7,4)) --> 4

print(bit:_or(5,2)) --> 7

--end of bit.lua

lua中的位運算

lua5.1不支援位操作 自己實現 數字轉二進位制 如下 其中需要注意的地方是 num num 2 並不像c中只得整數部分 所以需要處理一下值 用到了lua中math庫的math.modf 函式 函式用法如下所示 print math.modf 12.34 12 0.34數字轉二進位制 數字轉二進位...

用Lua實現位運算

由於做禮包啟用碼的時候需要對啟用碼進行一些位運算,所以就寫了這個模組。一般這些位運算操作建議還是在c 裡面寫,由於遊戲已經發出去了,只想用自動更新來更新這個功能,所以逼於無奈只能先用lua來實現一下。如果有朋友也是遇到不方便更新c 只想用lua來實現的話,希望這裡可以幫到你。module commo...

C C 位操作 位運算

在c語言中,可以單獨操控變數的位 bit 一般高階語言不會處理這級別的細節,c在提供高階語言便利的同時,還能為組合語言所保留的級別上工作,這使其成為編寫裝置驅動程式和嵌入式 的首選語言。目錄 二進位制整數 binary 有符號整數 八進位制 octal 十六進製制 hex 位運算子 按位與 的用途 ...