Bitwise XOR以SIGSEGV结尾

时间:2015-12-28 20:28:14

标签: c++ segmentation-fault xor bitwise-xor

我有一个函数,它应该执行简单的Bitwise-XOR加密。它看起来像这样:

void maskData(char* data, int length)
        {
            for(int i = 0; i < length; i++)
            {
                int j = i % 4;
                cout << bitset<8>(data[i]) << endl << bitset<8>(this->maskingKey[j]) << endl;
                data[i] ^= this->maskingKey[j];
            }
        }

该应用程序的输出是:

01010100
01001011

然后它就死了。我将gdb附加到它上面,发现引发了一个SIGSEGV异常。

01010100
01001011

Program received signal SIGSEGV, Segmentation fault.
0x00000000004100ea in WebSocketLayer::WebSocketFrame::maskData (
    this=0x7fffffffe190, data=0x423621 "This is a test", length=14)
    at ../BoostTransport/WebSocketLayer.h:130
130                 data[i] ^= this->maskingKey[j];

我真的不确定为什么会发生这种情况,一切似乎都对我好。

修改:更多代码:

    void setData(char* data, int length)
    {
                this->maskData(data, length);

     // ... ...
     }

wf.setData("This is a test", strlen("This is a test"));

循环在第一次运行时直接失败,这意味着ij为0。

1 个答案:

答案 0 :(得分:4)

我敢打赌data指向常数。你不能修改常数,这就是使它们成为常数的原因。所以任何与maskData("hello", 5);相当的东西都是非法的。这也是非法的:

char *j = "This is a test";
maskData(j, strlen(j));

在这里,j指向常数。你无法修改常量。