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);
我正在尝试对 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);