gpt4 book ai didi

c++ - XOR 128 位位集

转载 作者:塔克拉玛干 更新时间:2023-11-02 23:12:42 25 4
gpt4 key购买 nike

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

#include<iostream>
#include<bitset>

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

我得到的输出是 enter image description here

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

warning: integer constant is too large for its type

是否有某种方法可以对 128 位位集进行 XOR,或者我是否需要创建一个丑陋的 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);

关于c++ - XOR 128 位位集,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33239838/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com