【C#】关于左移/右移运算符的使用


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

 

继续送栗子:

比如 “(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。

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

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


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM