纯Lua实现的位操作

ZZMathBit = {}

function ZZMathBit.__andBit(left,right)
    return (left == 1 and right == 1) and 1 or 0    
end

function ZZMathBit.__orBit(left, right)
    return (left == 1 or right == 1) and 1 or 0
end

function ZZMathBit.__xorBit(left, right)
    return (left + right) == 1 and 1 or 0
end

function ZZMathBit.__base(left, right, op)
    if left < right then
        left, right = right, left
    end
    local res = 0
    local shift = 1
    while left ~= 0 do
        local ra = left % 2
        local rb = right % 2
        res = shift * op(ra,rb) + res
        shift = shift * 2
        left = math.modf( left / 2)
        right = math.modf( right / 2)
    end
    return res
end

function ZZMathBit.andOp(left, right)
    return ZZMathBit.__base(left, right, ZZMathBit.__andBit)
end

function ZZMathBit.xorOp(left, right)
    return ZZMathBit.__base(left, right, ZZMathBit.__xorBit)
end

function ZZMathBit.orOp(left, right)
    return ZZMathBit.__base(left, right, ZZMathBit.__orBit)
end

function ZZMathBit.notOp(left)
    return left > 0 and -(left + 1) or -left - 1 
end

function ZZMathBit.lShiftOp(left, num)
    return left * (2 ^ num)
end

function ZZMathBit.rShiftOp(left,num)
    return math.floor(left / (2 ^ num))
end

function ZZMathBit.test()
    print( ZZMathBit.andOp(65,0x3f))
    print(65 % 64)
    print( ZZMathBit.orOp(5678,6789))
    print( ZZMathBit.xorOp(13579,2468))
    print( ZZMathBit.rShiftOp(16,3))
    print( ZZMathBit.notOp(-4))

    print(string.byte("abc",1))
end

ZZMathBit.test()

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值