吐槽先~为什么我的老师大学时候没教过我这东西  - -、

继续送栗子:

比如 “(1+2)<<3”

你们猜等于几~

Debug.Log((1+2)<<3)之后输出的是“24”。

为什么呢~

因为呀因为呀  “

“左移/右移” 是指对应的二进制向左右移位,执行1+2=3,就变成了3<<3。即:把3对应的二进制向左移3位。

3对应的二进制:11   向左移3位变成 11000

二进制11000不就是十进制的24嘛~~~”

继续拓展一下思维

3>>1<<1 =?  一般人会想呀先向右移又向左移回来,结果肯定是3不会变呀~~~真·图样图森破!

自己算一下就会发现:

一个数向右移动一位后,所对应的二进制最后一位无论是1还是0,都已经没意义了,因为它消失了呀。然后,再向左移动一位,神奇的又增加的那一位又用0补上了。

所以,3变成2进制的“11”向右移动一位变成“1”,再向左移动一位变成了“10”,也就是2。

呵呵鉴于此刻无意间发现的这个惊天大秘密,以后再求小于等于某个数的偶数,就可以这样写嘛~

当然大家也可以继续开脑洞拓展一下,直到玩坏它。

05-11 09:31