XOR 128 位位集

XOR 128 bit bitsets

我正在尝试对 128 位位集进行异或运算。

#include<iostream>
#include<bitset>

int main()
{
  std::bitset<128> testing;
  testing = std::bitset<128>(0x544F4E20776E69546F656E772020656F) ^
  std::bitset<128>(0x5473206768204B20616D754674796E75);
  std::cout<<testing;
}

我得到的输出是

前64位为0,后64位异或。我还收到编译器警告

warning: integer constant is too large for its type

是否有某种方法可以对 128 位位集进行异或运算,或者我是否需要创建一个丑陋的 hack?

你的问题不是 XOR,而是从常量初始化位集。正如警告所说,整数常量的大小是有限制的,std::bitset 构造函数采用通常为 64 位长的 unsigned long long

您可以改为从二进制字符串初始化位集:

std::bitset<128>("100101010....")

或者从两个 64 位位集中组合它:

std::bitset<128> value = (std::bitset<128>(0x1234567890123456) << 64) | 
                         std::bitset<128>(0x1234567890123456);