首页 > 解决方案 > C++ 将 XOR 实现转换为 8 位(处理器不支持 XOR)

问题描述

该函数用于计算 32 位整数的异或

int xor32int(int x, int y)
{
    int res = 0; // Initialize result 

    // Assuming 32-bit Integer  
    for (int i = 31; i >= 0; i--)
    {
        // Find current bits in x and y 
        bool b1 = x & (1 << i);
        bool b2 = y & (1 << i);

        // If both are 1 then 0 else xor is same as OR 
        bool xoredBit = (b1 & b2) ? 0 : (b1 | b2);

        // Update result 
        res <<= 1;
        res |= xoredBit;
    }
    return res;
}

这在 XOR'ing 8 位值时工作正常,但首先需要将它们转换为 int,即

char byte1 = 0x23, byte2 = 0x34;
int result = xor32int((int)byte1, (int)byte2);

并且xor32int()假设输入为 32 位整数,它会运行 32 次循环,因此即使值只有 8 位,它也会在不必要时运行额外的循环,从而导致性能大幅下降。

我将如何转换xor32int()函数,使其仅适用于 8 位值,因此不需要循环 32 次?

如果您想知道我为什么不简单地使用 XOR 运算符,那是因为我正在使用一台使用不支持 XOR 的处理器的旧机器。

标签: c++xor32-bit8-bit

解决方案


你有没有理由不能使用(x | y) & ~(x & y)?这是异或的一种定义。你可以把它写成一个函数:

char xor8(char x, char y) {
    return (x | y) & ~(x & y);
}

您甚至可以将其编写为函数模板:

template<typename T>
T xorT(T x, T y) {
    return (x | y) & ~(x & y);
}

如果由于某种原因你不能使用它,我很确定你可以intchar, 和31替换7

char xor8char(char x, char y)
{
    char res = 0;

    for (int i = 7; i >= 0; i--)
    {
        bool b1 = x & (1 << i);
        bool b2 = y & (1 << i);

        bool xoredBit = (b1 & b2) ? 0 : (b1 | b2);

        res <<= 1;
        res |= xoredBit;
    }
    return res;
}

所有这一切,都生活在 Coliru 上。


推荐阅读