我不确定如何用这个问题来表述主题,因为我是位操作的新手,真的不了解它的工作原理。
我正在对游戏应用程序进行逆向工程,只是为了了解它的工作原理,并想弄清楚方法中'&'运算符的使用情况。
部分代码:
int n = (random numbers will be provided below)
int n2 = n & 1920 // interested in this line of code
switch (n2){
//ignore n2 value assignment inside of cases
case 256: {
n2 = 384;
break;
case 384: {
n2 = 512;
break;
case 512: {
n2 = 0
break;
测试值:
Input Values | Output Values | Substituting Values
n = 387 | n2 = 384 | ( 387 & 1920 ) = 384
n = 513 | n2 = 512 | ( 513 & 1920 ) = 512
n = 12546 | n2 = 256 | ( 12546 & 1920 ) = 256
n = 18690 | n2 = 256 | ( 18690 & 1920 ) = 256
基于此用例,我有几个问题:
在此示例中,&运算符在做什么?
数字1920
有什么重要意义?
他们是如何得出这个数字以达到特定的比特间隔的? (如果可能的话)
要了解位操作,您要做的第一件事是将所有以10为底的十进制数转换为显示位的数字格式,即以2为底的二进制数或以16为底的十六进制数(如果您已经学会了读那些)。
位从右开始编号,从0开始。
Decimal Hex Binary 256 = 0x100 = 0b1_0000_0000 384 = 0x180 = 0b1_1000_0000 512 = 0x200 = 0b10_0000_0000 1920 = 0x780 = 0b111_1000_0000 | | | | | 10 8 7 4 0 Bit Number
如您所见,
n & 1920
将清除除7-10位以外的所有字符。
只要n
没有任何大于10的设置位,即大于0x7FF = 2047
,则效果如您所述,这些值将四舍五入(截断)到最近的位间隔,即128。
128 + 256 + 512 + 1024 = 1920.
These are also powers of 2. let ^ be power of.
128 = 2^7
256 = 2^8
512 = 2^9
1024 = 2^10