lua 中的 bit extend 库 (可能仅对非负数有效)

-- bit operation


bit = bit or {}
bit.data32 = {}


for i=1,32 do
    bit.data32[i]=2^(32-i)
end


function bit._b2d(arg)
    local nr=0
    for i=1,32 do
        if arg[i] ==1 then
            nr=nr+bit.data32[i]
        end
    end
    return  nr
end


function bit._d2b(arg)
    arg = arg >= 0 and arg or (0xFFFFFFFF + arg + 1)
    local tr={}
    for i=1,32 do
        if arg >= bit.data32[i] then
            tr[i]=1
            arg=arg-bit.data32[i]
        else
            tr[i]=0
        end
    end
    return   tr
end


function    bit._and(a,b)
    local op1=bit._d2b(a)
    local op2=bit._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
        end
    end
    return  bit._b2d(r)


end


function  bit._xor(a,b)
    local op1 = bit._d2b(a)
    local op2 = bit._d2b(b)
    local r={}
    for i = 1,32 do
        if op1[i] == 0 then
            r[i] = op2[i]
        else
            if op2[i] == 0 then
                r[i] = 1
            else
                r[i] = 0
            end
        end
    end
    return bit._b2d(r)
end


function    bit._rshift(a,n)
    local op1=bit._d2b(a)
    n = n <= 32 and n or 32
    n = n >= 0 and n or 0


    for i=32, n+1, -1 do
        op1[i] = op1[i-n]
    end
    for i=1, n do
        op1[i] = 0
    end


    return  bit._b2d(op1)
end


function bit._lshift(a,n)
    local op1 =bit._d2b(a)
    n = n <= 32 and n or 32
    n = n >= 0 and n or 0
    for i = 1, 32 - n do
        op1[i] = op1[i + n]
    end
    for i = 32 - n + 1, 32 do
        op1[i] = 0
    end
    return bit_b2d(op1)
end


function bit._not(a)
    local op1=bit._d2b(a)
    local r={}


    for i=1,32 do
        if  op1[i]==1   then
            r[i]=0
        else
            r[i]=1
        end
    end
    return bit._b2d(r)
end


function bit._or(a,b)
    local op1=bit._d2b(a)
    local op2=bit._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
        end
    end
    return bit._b2d(r)
end


bit.band   = bit.band or bit._and
bit.rshift = bit.rshift or bit._rshift
bit.bnot   = bit.bnot or bit._not
bit.lshift = bit.lshift or bit._lshift
bit.xor = bit.xor or bit._xor
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值