搜尋
首頁Javajava教程詳解Java二進位操作(動力節點整理)
詳解Java二進位操作(動力節點整理)Mar 31, 2017 am 10:29 AM
java二進位

這篇文章為大家介紹了java二進位操作技巧,包括移位、位元運算操作符等相關知識點,非常不錯,有興趣的朋友參考下吧

移位

位元運算中大多數操作都是向左移位和向右移位。在Java中,這對應著>這兩個運算符,範例如下:

/* 00000001 << 1 = 00000010 */
1 << 1 == 2 
/* 00000001 << 3 = 00001000 */
1 << 3 == 8
/* 11111111 11111111 11111111 11110000 >> 4 = 11111111 11111111 11111111 11111111 */
0xFFFFFFF0 >> 4 == 0xFFFFFFFF 
/* 00001111 11111111 11111111 11111111 >> 4 = 00000000 11111111 11111111 11111111 */
0x0FFFFFFF >> 4 == 0x00FFFFFF

注意:向右移位是有符號運算子。和許多語言一樣,Java使用最高位元來表示數值的正負,負數的最高位元永遠是1。一個以1開頭的二進制數移位後還將以1開頭,一個以0開頭的二進制樹移位後還將以0開頭。所以要小心:Java是可以在整數中進行位元運算的。

你可以使用叫作「無符號右移」運算子的第三個運算子:>>> 來實現以「0」填充的移位,這種移位會忽略符號位並總是用「0」來填滿。

/* 10000000 00000000 00000000 00000000 >>> 1 = 01000000 00000000 00000000 00000000 */
0x80000000 >>> 1 == 0x40000000
/* 10000000 00000000 00000000 00000000 >> 1 = 11000000 00000000 00000000 00000000 */
0x80000000 >> 1 == 0xC0000000

最大的用途之一是快速求2的冪。 1向左移位1位是2,移2位是4,移3位是8… 相似的,向右移1位相當於是把該數除以2。

另一個用途是建立遮罩。位元遮罩可用於屏蔽或修改一個二進制數中的某些指定位,下一部分會進行詳細講解。假如我們想要創建一個

00001000的掩碼,程式碼十分簡單:

int bitmask = 1 << 3;

你可以使用位元運算運算元來建立更複雜的掩碼,下一部分同樣會講解位元運算操作符。

位元運算運算子

以下是Java中四個常見的位元運算子:

  • # ~ – 按位取反

  •  & – 位元與

  •  ~ – 位元異或

  •  | – 位元或

  •  簡單應用如下(簡單起見,只顯示二進位)

##

1010 & 0101 == 0000
1100 & 0110 == 0100
1010 | 0101 == 1111
1100 | 0110 == 1110
~1111 == 0000
~0011 == 1100
1010 ^ 0101 == 1111
1100 ^ 0110 == 1010
例如,你可以透過「或」運算,把一個二進位數上的指定位元「設定」為1,並且不會影響到其他位元。
10000001 | 00100000 = 10100001 /* 第五位设为1 */
10000001 | 1 << 5 = 10100001 /* 同样作用 */
00000000 | 1 << 2 | 1 << 5 = 00100100

如果你想要選擇性的把某位設為0,你可以讓數與一個全1但是某位為0的數相與。

01010101 & ~(1<<2) == 01010101 & 11111011 == 01010001
關於位元順序


假設最高位元在左邊:

10010110
^   ^
|   |------- 第 0 位
|
|-------------- 第 7 位

注意,第0位元的值是2^0,第一位是2^1,…,第7位的值是2^7。

使用ParseInt

#########在你的程式碼裡操作二進位數字的便利方法是使用Integer.parseInt()方法。 Integer.parseInt(“101″,2)代表著把二進位數101轉換為十進位數(5)。這意味著,利用這個方法你甚至可以在###for循環###裡使用二進位數字:###
/* 从5到15的循环 */
for (int b = Integer.parseInt("0101",2); b <= Integer.parseInt("1111",2); b++) {
  /* 做些什么 */
}
#########位元讀寫########## ##建議:自己實作一個用來把二進位位元(位元)轉換為流並讀寫的類,盡量不要使用Java的輸入輸出流,因為Java的流只能按位元組操作。你會覺得「給我接下來的N個位元」和「把指標往前移M位元」這種功能是非常實用的。例如,你可以讀取足夠的資料來確定最長的霍夫曼編碼的長度,當你得到你剛剛讀取的霍夫曼編碼的實際長度之後,你就可以把指針往前移相應長度。一個這樣的類別可以把位元運算醜陋的一面分成一個眼熟的程式碼區塊。 #########類似的,如果你追求速度的話,那你會意外的發現表查找是如此強大。假如你有一個霍夫曼編碼以0開頭,並且其他的編碼長度均為3而且以1開頭,這意味著你需要一個可以容納8(2^3)個項的###表格###,你的表格可能是這樣的:###
char code[8];
int codelen[8];
code[0] = &#39;a&#39;; codelen[0] = 1;
code[1] = &#39;a&#39;; codelen[1] = 1;
code[2] = &#39;a&#39;; codelen[2] = 1;
code[3] = &#39;a&#39;; codelen[3] = 1;
code[4] = &#39;b&#39;; codelen[4] = 3;
code[5] = &#39;c&#39;; codelen[5] = 3;
code[6] = &#39;d&#39;; codelen[6] = 3;
code[7] = &#39;e&#39;; codelen[7] = 3;
###透過兩次查找,你就可以定位到你要找的字符,並且還可以知道下一個字符在前面多少位置。這可要比某些一遍遍的循環去查找全部字元要划算的多,也更節省記憶體。 ###

以上是詳解Java二進位操作(動力節點整理)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
带你搞懂Java结构化数据处理开源库SPL带你搞懂Java结构化数据处理开源库SPLMay 24, 2022 pm 01:34 PM

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于结构化数据处理开源库SPL的相关问题,下面就一起来看一下java下理想的结构化数据处理类库,希望对大家有帮助。

Java集合框架之PriorityQueue优先级队列Java集合框架之PriorityQueue优先级队列Jun 09, 2022 am 11:47 AM

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于PriorityQueue优先级队列的相关知识,Java集合框架中提供了PriorityQueue和PriorityBlockingQueue两种类型的优先级队列,PriorityQueue是线程不安全的,PriorityBlockingQueue是线程安全的,下面一起来看一下,希望对大家有帮助。

完全掌握Java锁(图文解析)完全掌握Java锁(图文解析)Jun 14, 2022 am 11:47 AM

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于java锁的相关问题,包括了独占锁、悲观锁、乐观锁、共享锁等等内容,下面一起来看一下,希望对大家有帮助。

一起聊聊Java多线程之线程安全问题一起聊聊Java多线程之线程安全问题Apr 21, 2022 pm 06:17 PM

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于多线程的相关问题,包括了线程安装、线程加锁与线程不安全的原因、线程安全的标准类等等内容,希望对大家有帮助。

Java基础归纳之枚举Java基础归纳之枚举May 26, 2022 am 11:50 AM

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于枚举的相关问题,包括了枚举的基本操作、集合类对枚举的支持等等内容,下面一起来看一下,希望对大家有帮助。

详细解析Java的this和super关键字详细解析Java的this和super关键字Apr 30, 2022 am 09:00 AM

本篇文章给大家带来了关于Java的相关知识,其中主要介绍了关于关键字中this和super的相关问题,以及他们的一些区别,下面一起来看一下,希望对大家有帮助。

Java数据结构之AVL树详解Java数据结构之AVL树详解Jun 01, 2022 am 11:39 AM

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于平衡二叉树(AVL树)的相关知识,AVL树本质上是带了平衡功能的二叉查找树,下面一起来看一下,希望对大家有帮助。

java中封装是什么java中封装是什么May 16, 2019 pm 06:08 PM

封装是一种信息隐藏技术,是指一种将抽象性函式接口的实现细节部分包装、隐藏起来的方法;封装可以被认为是一个保护屏障,防止指定类的代码和数据被外部类定义的代码随机访问。封装可以通过关键字private,protected和public实现。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具