我如何按位XOR两个C char数组?

时间:2015-01-13 02:58:48

标签: c arrays char bit-manipulation xor

我觉得因为无法解决这个问题而感到愚蠢,但我迷失了。我试图对两个C字符串进行异或。

#include <stdio.h>
#include <memory.h>
#include <stdlib.h>
int main()
{
    char plainone[16]; 
    char plaintwo[16];
    char xor[17];
    strcpy(plainone, "PlainOne");
    strcpy(plaintwo, "PlainTwo");
    int i=0;
    for(i=0; i<strlen(plainone);i++)
        xor[i] ^= (char)(plainone[i] ^ plaintwo[i]);
    printf("PlainText One: %s\nPlainText Two: %s\n\none^two: %s\n", plainone, plaintwo, xor);
    return 0;
}

我的输出是:

$ ./a.out 
PlainText One: PlainOne
PlainText Two: PlainTwo

one^two: 

为什么xor数组不能读作什么?

2 个答案:

答案 0 :(得分:12)

处理XOR后,您正在处理可能不是可打印ASCII字符的二进制字节。

当你对彼此的相同字符进行XOR时,你得到0.所以'P' ^ 'P'将为0.这是一个NUL字节,它终止了字符串。如果您尝试使用printf()打印,则什么也得不到; printf()认为字符串是一个终止的长度为0的字符串。

此外,您只需使用=将XOR结果分配到目标缓冲区,而不是像程序那样使用^=

这是我的程序版本和输出:

#include <stdio.h>
#include <memory.h>
#include <stdlib.h>

#define LENGTH 16
int main()
{
    char const plainone[LENGTH] = "PlainOne";
    char const plaintwo[LENGTH] = "PlainTwo";
    char xor[LENGTH];
    int i;

    for(i=0; i<LENGTH; ++i)
        xor[i] = (char)(plainone[i] ^ plaintwo[i]);
    printf("PlainText One: %s\nPlainText Two: %s\n\none^two: ", plainone, plaintwo);
    for(i=0; i<LENGTH; ++i)
        printf("%02X ", xor[i]);
    printf("\n");
    return 0;
}

输出:

PlainText One: PlainOne
PlainText Two: PlainTwo

one^two: 00 00 00 00 00 1B 19 0A 00 00 00 00 00 00 00 00

注意前五个字节都是00,因为PlainPlain进行了异或。

答案 1 :(得分:2)

好“普通”xor“普通”== 00000,0是终结者字符。 C字符串打印到终止符,这意味着它什么都不打印。