(JAVA学习笔记) 如何计算2*8效率高(面试题)—— 左移和右移问题。
生活随笔
收集整理的這篇文章主要介紹了
(JAVA学习笔记) 如何计算2*8效率高(面试题)—— 左移和右移问题。
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
左移和右移問題
面試題中如何計算(2×8)效率高。
這里的效率肯定是指計算機運算的效率,平常進行計算時直接在代碼中寫2*8就可以直接得出結果,但是對于計算機而言是無法直接識別的,看似結果出來的很快,但實際上計算機是經(jīng)歷相當多的繁瑣的過程轉換才最終得出結果的。
那么如何讓計算機更有效率的進行計算2×8呢?
這里就涉及到了位運算中的左移<<和右移>>的問題。直接上代碼:
結果:
這里直接得出了2×8的結果。計算機能夠直接識別二進制數(shù)。
而位運算是對二進制數(shù)進行運算,左移一位相當于二進制數(shù)往左移了一位。
2=10(二進制) ,左移三位后變?yōu)?16=1000(二進制)。
所以2×8用2<<3運算更有效率。
在底層代碼中,左移和右移是效率極其高的運算方式。
總結
以上是生活随笔為你收集整理的(JAVA学习笔记) 如何计算2*8效率高(面试题)—— 左移和右移问题。的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: (JAVA学习笔记) 关于i++和++i
- 下一篇: (JAVA学习笔记) Scanner类中