二进制处理函数

unsigned const STAT_ZERO = 0x0008;
unsigned const STAT_ONE = 0x0002;
unsigned const STAT_TWO = 0x0004;
unsigned const STAT_THREE = 0x0008;

// 检测位有1位是1就返回true
template <class T, class U>
bool isAnyBitSet(T value, U mask)
{
    if ((value & mask) != 0)
        return true;
    else
        return false;
}
// 检测位所有位都为1才返回true
template <class T, class U>
bool areAllBitsSet(T value, U mask)
{
    if ((value & mask) == mask)
        return true;
    else
        return false;
}
// 检测位全为0返回false
template <class T, class U>
bool areAllBitsClear(T value, U mask)
{
    if ((value & mask) == 0)
        return true;
    else
        return false;
}
// 置位
template <class T, class U>
T setBits(T value, U mask)
{
    return (value | mask);
}
// 除了屏蔽位,其他全置位
template <class T, class U>
T setBitsExcept(T value, U mask)
{
    return (value | ~mask);
}
// 清除指定位
template <class T, class U>
T clearBits(T value, U mask)
{
    return (value & ~mask);
}
// 除了屏蔽位,其他全清0
template <class T, class U>
T clearBitsExcept(T value, U mask)
{
    return (value & mask);
}
// n指定位置
template <class T>
T setBitByPos(T value, unsigned char n)
{
    return (value | (1 << n));
}
template <class T>
T clearBitByPos(T value, unsigned char n)
{
    return (value & ~(1 << n));
}
// 先置位add指定位,再清remove指定位为0
template <class T, class U>
T setBitByPos(T value, U add, U remove)
{
    return ((value | add ) & ~remove);
}
template <class T>
bool isBitSetByPos(T value, unsigned char n)
{
    if ((value & (1 << n)) != 0)
        return true;
    else
        return false;
}

template <class T>
bool isBitClearByPos(T value, unsigned char n)
{
    if ((value & (1 << n)) == 0)
        return true;
    else
        return false;
}
// 获取二进制1个数
template <class T>
long getOneNum(T value)
{
    int loop = sizeof(T)*8;
    if (loop > sizeof(long)*8)
    {
        printf("value's bitwidth cannot longer than one word");
        return 0;
    }
    int n=0;
    int num = 0;
    while (loop--)
    {
        if (isBitSetByPos(value, n++))
            num++;
    }
    return num;
}
// 获取二进制0个数
template <class T>
long getZeroNum(T value)
{
    int loop = sizeof(T)*8;
    if (loop > sizeof(long)*8)
    {
        printf("value's bitwidth cannot longer than one word");
        return 0;
    }
    int n=0;
    int num = 0;
    while (loop--)
    {
        if (isBitClearByPos(value, n++))
            num++;
    }
    return num;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值