zoukankan      html  css  js  c++  java
  • [手游项目2]-3- lua位操作

    --[[{2147483648,1073741824,536870912,268435456,134217728,67108864,33554432,16777216,
            8388608,4194304,2097152,1048576,524288,262144,131072,65536,
            32768,16384,8192,4096,2048,1024,512,256,128,64,32,16,8,4,2,1}
            ]]




    bit={data32={}}
    for i=1,32 do
        bit.data32[i]=2^(32-i)
    end
    --整数转换成位
    function 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
            end
        end
        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)
            end
        end
        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
            end
        end
        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
            end
        end
        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
            end
        end
        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
            end
        end
        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]
                end
                op1[1]=0
            end
        r=op1
        end
        return  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]
                end
                op1[32]=0
            end
        r=op1
        end
        return  self:b2d(r)
    end --bit:_lshift


    --打印位
    function    bit:print(ta)
        local   sr=""
        for i=1,32 do
            sr=sr..ta[i]
        end
        print(sr)
    end


    --获得某一位的值0或1
    function    bit:getb(a,n)
    if(n < 1 or 32< n)then
    return 0
    end
    if(0 < bit:_and(a,self.data32[33-n]))then
    return 1
    end
    return 0
    end


    --设置某一位的值为1
    function    bit:setb_1(a,n)
    if(n < 1 or 32< n)then
    return 0
    end
    return bit:_or(a,self.data32[33-n])
    end


    --设置某一位的值为0
    function    bit:setb_0(a,n)
    if(n < 1 or 32< n)then
    return 0
    end
    return bit:_and(a, bit:_not(self.data32[33-n]))
    end


    --[[
    bs=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
    print(bit:getb(7,3))
    print(bit:setb_0(5,3))
    ]]
    --end of bit.lua
  • 相关阅读:
    Abp vNext 模块化系统简单介绍
    CLR via C# 笔记 -- 计算限制的异步操作(27)
    CLR via C# 笔记 -- 线程基础(26)
    Redis 入门
    .NET Core 中生成验证码
    CLR via C# 笔记 -- 异常和状态管理(20)
    CLR via C# 笔记 -- 托管堆和垃圾回收(21)
    CLR via C# 笔记 -- 字符、字符串、文本处理(14)
    广州公司黑名单
    总博客教程全导航
  • 原文地址:https://www.cnblogs.com/byfei/p/14104238.html
Copyright © 2011-2022 走看看