0

所以基本上我有一些 NSData 对象和一个看起来像这样的方法:

+ (NSData *)outputData:(NSData *)data andThisData:(NSData *)secondData {
    char cData[data.length];
    [data getBytes:&cData];

    char cSecondData[secondData.length];
    [secondData getBytes:&cSecondData];

    NSLog(@"NSData: %@, %@", data, secondData);
    NSLog(@"HEX: %x, %x",cData,cSecondData);
}

我正在为两个单独的 NSData 对象获取此输出,它们在表面上看起来相同:

 NSData: <dc4945fa a76fa1eb 6c3de73e acabf71c>, <c7a75cfc 11697878 14b95c2b 8680b60b ed553909 d199c12b 6e66df1d 20dce6e5 46ef9cf6 0aefa4ee bf98b0d1 6579a311>
    HEX: 5fbfe870, 5fbfe840

 NSData: <dc4945fa a76fa1eb 6c3de73e acabf71c>, <c7a75cfc 11697878 14b95c2b 8680b60b ed553909 d199c12b 6e66df1d 20dce6e5 46ef9cf6 0aefa4ee bf98b0d1 6579a311>
    HEX: 5fbfe820, 5fbfe7f0

正如您所看到的 NSData 输出完全相同,但char它们产生的十六进制是不同的(尽管非常相似)。这会抛出一些计算和进一步计算的输出,但我不明白为什么它们会有所不同。

那么在什么情况下会出现这种情况呢?我该如何补救?

非常感谢。(如果您需要更多信息,请告诉我)。

4

1 回答 1

3

您没有打印缓冲区中的数据。您正在打印两个本地数组的地址衰减到的指针。如果您实际打印数据,它们将是相同的:

NSMutableString *hex = [NSMutableString string], *secondHex = [NSMutableString string];
for (int i = 0; i < sizeof(cData); i++) {
    [hex appendFormat:@"%02x", cData[i]];
    [secondHex appendFormat:@"%02x", cSecondData[i]];
}

NSLog(@"%@ %@", hex, secondHex);
于 2013-04-05T17:21:46.383 回答