草庐IT

bitwise-xor

全部标签

c++ - C/C++ : Bitwise operators on dynamically allocated memory

在C/C++中,是否有一种简单的方法可以将按位运算符(特别是左移/右移)应用于动态分配的内存?例如,假设我这样做了:unsignedchar*bytes=newunsignedchar[3];bytes[0]=1;bytes[1]=1;bytes[2]=1;我想要一种方法来做到这一点:bytes>>=2;(那么“字节”将具有以下值):bytes[0]==0bytes[1]==64bytes[2]==64为什么值应该是这样的:分配后,字节如下所示:[00000001][00000001][00000001]但我希望将字节视为一长串位,如下所示:[000000010000000100000

javascript - 为什么单行 XOR 交换在 Javascript 中不起作用但在 C++ 中起作用?

这个问题在这里已经有了答案:ChainedassignmentofvariableswithoperatorsinJavaScript(2个答案)关闭7年前。在javascript中,如果我写:vara=6;varb=4;a^=b^=a^=b;console.log(a,b);结果将是06。但如果我写:vara=6;varb=4;a^=b;b^=a;a^=b;console.log(a,b);结果将是46。这是正确的。为什么这种在javascript中的单行异或交换方式不起作用?为什么它在C++中运行良好?

c++ - SSE 内在函数 : masking a float and using bitwise and?

基本上这个问题与x86汇编器有关,您有一个数字,您希望使用and将其设置为零或数字本身。.如果你andnumber为负数你会得到number本身,但如果你and它与零你得到零。现在我在使用SSEinstrinsics时遇到的问题是float在二进制中与double不同(或者我弄错了)。无论如何,这是代码,我尝试使用各种float来掩盖第二个和第三个数字(分别为127.0f和99.0f),但没有成功。#include#includevoidprint_4_bit_num(constchar*label,__m128var){float*val=(float*)&var;printf("%

c++ - && 在 bitwise_cast<void*>(&&__opcode) 上下文中的含义;

我正在查看下面来自JavascriptCore的代码,但我不知道&&在下面的上下文中的含义。地址的地址没有任何意义。有人可以解释下&&在下面的上下文中的含义吗。(bitwise_cast使用union来避免reinterpret_cast带来的严格别名问题)下面的代码在clang(可能还有gcc)上编译,但不在我们自己专有的C++编译器上编译。可以找到完整的源代码here.#ifENABLE(COMPUTED_GOTO_OPCODES)Opcode*opcodeMap=LLInt::opcodeMap();#defineOPCODE_ENTRY(__opcode,length)\opc

c++ - XOR 高 32 位与 64 位数字中的低 32 位

在64位数字中如何对高位32位与低位32位进行异或。谢谢 最佳答案 (v&0xffffffff)^((v>>32)&0xffffffff) 关于c++-XOR高32位与64位数字中的低32位,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/6370897/

c++ - XOR AL,AL + MOVZX EAX, AL 比 XOR EAX,EAX 有什么优势?

我有一些未知的C++代码是在发布版本中编译的,因此对其进行了优化。我正在努力解决的问题是:xoral,aladdesp,8cmpbyteptr[ebp+userinput],31hmovzxeax,al这是我的理解:xoral,al;seteaxto0x??????00(clearlastbyte)addesp,8;forsomeunclearreason,setthestackpointerhighercmpbyteptr[ebp+userinput],31h;setzeroflagifuserinputwas"1"movzxeax,al;seteaxtoALandextendwit

c++ - 添加每个可能的 xor-sum 子数组的和的算法

我参加了一次算法竞赛。我遇到了一个问题,我在这里问同样的问题。问题陈述XOR-sumarray是对该子数组的所有数字进行异或。给你一个数组,你必须添加所有可能的异或子数组。为了更好的理解,问题陈述是here还有。示例输入数组:-12输出:-6解释F(1,1)=A[1]=1,F(2,2)=A[2]=2和F(1,2)=A[1]XORA[2]=1XOR2=3。因此答案是1+2+3=6。我的代码时间复杂度:-O(N^2),(效率低下,未参加比赛)#includeusingnamespacestd;longlongintinput[100001];main(){intT;intN;longlon

c++ - XOR 交换算法中运算符的未定义行为?

voidswap(int*a,int*b){if(a!=b)*a^=*b^=*a^=*b;}因为上面的*a^=*b^=*a^=*b只是*a=*a^(*b=*b^(*a=*a^*b)),可以(例如)在第三个*a之前对第二个*a进行求值(对于XOR)修改(由=)?用C99/C11/C++98/C++11写有关系吗? 最佳答案 C++11标准说:5.17/1:Theassignmentoperator(=)andthecompoundassignmentoperatorsallgroupright-to-left.(...)theassi

c++ - 带有插入符号操作的字符 XOR

我很清楚在位上使用异或。但在这里,XOR处理的是单个字符。那么这是否意味着构成字符的字节正在被异或?这看起来像什么?#includeintmain(){charstring[11]="Anicecat";charkey[11]="ABCDEFGHIJ";for(intx=0;x我知道位XORed看起来像这样:101011000110 最佳答案 XOR有一个很好的特性,即如果您使用相同的数据对某些内容进行两次XOR,您将获得原始数据。您发布的代码是一些基本的加密功能,它使用key“加密”字符串。生成的密文可以通过相同的程序进行解密。

c++ - "Bitwise And"和 C++ 中的左填充

我有一个看起来像这样的宏:Foo(x)((x-'!')&070)如果我调用下面的代码:Foo('1')=>16但是,如果我调用下面的代码:(('1'-'!')&70)=>0所以我的问题是,这是怎么回事?为什么x&070计算为x而x&70计算为0?我的猜测是,左边多出的0迫使60占用2个字节,而不是1个字节。这样的话,按位&不会如下所示吗?0000000000010000'160000000001000110&'70-------------------0000000000000000 最佳答案 在C++中,以0开头的常量是八进制常量