为什么这个功能:
uint64_t rot_xor(uint64_t a1, uint64_t a2) {
int size = sizeof(a1)*4;
cout<<" "<<"size:"<<bitset<8>(size).to_string()<<" "<<size;
int shift;
uint64_t output = 0;
cout<<endl;
for (shift = 0; shift < size; shift++)
if(a1&(1<<shift)) {
output ^= (a2 << shift) | (a2 >> (size - shift));
cout << bitset<64>(output).to_string()<<endl;
}
return output;
}
打印输出:
答案 0 :(得分:0)
第1点
如果问题是为什么你的程序打印20因为似乎是sizeof(uint64_t) * 4
而不是32,那么它是因为在调用rot_xor
之前有一些行有一个:
cout << hex
事实上,您发布的链接中可以看到的确切输出是
size:00100000 20
二进制和十六进制表示的或32。
第2点
我不知道您的预期输出应该是什么样的。