亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

首頁 Java Java入門 java中的位元運算及應(yīng)用場景介紹

java中的位元運算及應(yīng)用場景介紹

Mar 08, 2021 pm 04:32 PM
java 位元運算 應(yīng)用場景

java中的位元運算及應(yīng)用場景介紹

我們知道程式中的所有數(shù)在電腦記憶體中都是以二進(jìn)位的形式儲存的,而位元運算就是直接對整數(shù)在記憶體中的二進(jìn)位位元進(jìn)行操作。例如,and運算本來就是邏輯運算符,但整數(shù)與整數(shù)之間也可以進(jìn)行and運算。

位元運算主要有移位運算和邏輯運算。下面我們就分別來講講移位運算和邏輯運算。

移位運算:

左移:運算子為<<,向左移動,右邊的低位補0,左邊高位捨棄,將二進(jìn)位看做整數(shù),左移1位就相當(dāng)於乘以2。無符號右移:運算子為>>>,向右移動,右邊的捨棄掉,左邊補0。有符號右移:操作符為>>,向右移動,右邊的捨棄掉,左邊補的值取決於原來最高位,原來是1就補1,原來是0就補0,將二進(jìn)位看做整數(shù),右移1位相當(dāng)於除以2。

例如:

int a = 4; // 100
a = a >> 2; // 001,等于1
a = a << 3 // 1000,變?yōu)?

邏輯運算有:

  • #位元與&:兩位都為1才為1

  • 按位元或|:只要有一位為1,就為1

  • #位元取反~: 1變成0,0變成1

  • 按位異或^ :相異為真,相同為假

例如:

int a = ...; 
a = a & 0x1 // 返回0或1,就是a最右邊一位的值。
a = a | 0x1 //不管a原來最右邊一位是什么,都將設(shè)為1

我們來看幾個簡單的應(yīng)用場景:

場景一:判斷奇偶

分析:奇數(shù)都不是2的整數(shù)倍,轉(zhuǎn)換成二進(jìn)位後最低位必然為1,偶數(shù)則相反。利用這個特性我們可以很容易的通過位運算判斷一個整數(shù)的奇偶性。

看程式碼:

   int i = 1;// 二進(jìn)制存儲方式為00000000000000000000000000000001
    int j = 5;// 二進(jìn)制存儲方式為00000000000000000000000000000101
    int k = 6;// 二進(jìn)制存儲方式為00000000000000000000000000000110
    if ((i & j) == 1) {
      System.out.println("j的最低位為1,為奇數(shù)");
    }    if ((i & k) == 0) {
      System.out.println("k的最低位為0,為偶數(shù)");
    }

場景二:判斷一個正整數(shù)是不是2的整數(shù)次方

分析:我們先來看看常見的2的整數(shù)次冪的數(shù):2、4、8、16,轉(zhuǎn)換成二進(jìn)位依序為:10、100、1000、10000,發(fā)現(xiàn)規(guī)律了沒有?那就是除了首位是1,其他全是0。恰巧這些數(shù)減去1後等於他們依序按位取反的結(jié)果,例如8-1=7,二進(jìn)制是111,可以透過8的二進(jìn)制1000按位取反得到。而8&7=0,提取一下規(guī)律就是:

(n&(n-1))==0

符合這個規(guī)律的n就是2的整數(shù)次方了。

(學(xué)習(xí)影片分享:java影片教學(xué)

場景三:簡單的集合處理

不廢話,直接看程式碼:

public class SimpleSet {  public static final int A = 0x01;// 最后四位為0001
  public static final int B = 0x02;// 最后四位為0010
  public static final int C = 0x04;// 最后四位為0100
  public static final int D = 0x08;// 最后四位為1000
  private int set = 0x00;// 初始0000,空集合
  public void add(int i) {// 將i對應(yīng)位的值置為1,重復(fù)add不影響。默認(rèn)傳入值為ABCD之一,此處省去邊界判斷
    set |= i;
  }  public boolean contain(int i) {// 判斷相應(yīng)位置是否為1
    return (set & i) == i;
  }  public boolean remove(int i) {// 來不及不解釋了快看代碼
    if (contain(i)) {
      set -= i;      return true;
    } else {      return false;
    }
  }
}

測試一下:

 public static void main(String[] args) {
    SimpleSet set = new SimpleSet();
    System.out.println(set.contain(A));
    set.add(B);
    System.out.println(set.contain(A));
    System.out.println(set.contain(B));
    set.add(A);
    set.add(C);
    System.out.println(set.contain(A));
    set.remove(A);
    System.out.println(set.contain(A));
    System.out.println(set.remove(A));
    System.out.println(set.contain(C));
  }

輸出為:

false
false
true
true
false
false
true

好的,沒有問題。

大家可能會覺得,上面的範(fàn)例程式碼中的A、B、C、D有點類似枚舉,事實上jdk原始碼中的關(guān)於枚舉的集合類別EnumSet使用的就是類似的方案,當(dāng)然比這個複雜得多,有興趣的可以去翻一下源碼,這個方案它有個名字,叫位向量。

順便提一句,java中int的包裝類別Integer裡面有很多靜態(tài)工具方提供位元運算操作,而且大都十分複雜,有興趣的可以去看看

結(jié)語:

位元運算是電腦最擅長的運算,jdk的原始碼中也大量使用了它,搞清楚它有助於我們更深入的理解計算機(jī),也有助於我們寫出更優(yōu)雅的程式碼??。?

相關(guān)推薦:java入門教學(xué)

#

以上是java中的位元運算及應(yīng)用場景介紹的詳細(xì)內(nèi)容。更多資訊請關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強(qiáng)大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

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

熱門話題

Laravel 教程
1597
29
PHP教程
1488
72
VSCODE設(shè)置。 JSON位置 VSCODE設(shè)置。 JSON位置 Aug 01, 2025 am 06:12 AM

settings.json文件位於用戶級或工作區(qū)級路徑,用於自定義VSCode設(shè)置。 1.用戶級路徑:Windows為C:\Users\\AppData\Roaming\Code\User\settings.json,macOS為/Users//Library/ApplicationSupport/Code/User/settings.json,Linux為/home//.config/Code/User/settings.json;2.工作區(qū)級路徑:項目根目錄下的.vscode/settings

如何使用JDBC處理Java的交易? 如何使用JDBC處理Java的交易? Aug 02, 2025 pm 12:29 PM

要正確處理JDBC事務(wù),必須先關(guān)閉自動提交模式,再執(zhí)行多個操作,最後根據(jù)結(jié)果提交或回滾;1.調(diào)用conn.setAutoCommit(false)以開始事務(wù);2.執(zhí)行多個SQL操作,如INSERT和UPDATE;3.若所有操作成功則調(diào)用conn.commit(),若發(fā)生異常則調(diào)用conn.rollback()確保數(shù)據(jù)一致性;同時應(yīng)使用try-with-resources管理資源,妥善處理異常並關(guān)閉連接,避免連接洩漏;此外建議使用連接池、設(shè)置保存點實現(xiàn)部分回滾,並保持事務(wù)盡可能短以提升性能。

在Java的掌握依賴注入春季和Guice 在Java的掌握依賴注入春季和Guice Aug 01, 2025 am 05:53 AM

依賴性(di)IsadesignpatternwhereObjectsReceivedenciesenciesExtern上,推廣looseSecouplingAndEaseerTestingThroughConstructor,setter,orfieldInjection.2.springfraMefringframeWorkSannotationsLikeLikeLike@component@component,@component,@service,@autowiredwithjava-service和@autowiredwithjava-ligatiredwithjava-lase-lightike

如何使用Java的日曆? 如何使用Java的日曆? Aug 02, 2025 am 02:38 AM

使用java.time包中的類替代舊的Date和Calendar類;2.通過LocalDate、LocalDateTime和LocalTime獲取當(dāng)前日期時間;3.使用of()方法創(chuàng)建特定日期時間;4.利用plus/minus方法不可變地增減時間;5.使用ZonedDateTime和ZoneId處理時區(qū);6.通過DateTimeFormatter格式化和解析日期字符串;7.必要時通過Instant與舊日期類型兼容;現(xiàn)代Java中日期處理應(yīng)優(yōu)先使用java.timeAPI,它提供了清晰、不可變且線

了解Java虛擬機(jī)(JVM)內(nèi)部 了解Java虛擬機(jī)(JVM)內(nèi)部 Aug 01, 2025 am 06:31 AM

TheJVMenablesJava’s"writeonce,runanywhere"capabilitybyexecutingbytecodethroughfourmaincomponents:1.TheClassLoaderSubsystemloads,links,andinitializes.classfilesusingbootstrap,extension,andapplicationclassloaders,ensuringsecureandlazyclassloa

Google Chrome無法打開本地文件 Google Chrome無法打開本地文件 Aug 01, 2025 am 05:24 AM

ChromecanopenlocalfileslikeHTMLandPDFsbyusing"Openfile"ordraggingthemintothebrowser;ensuretheaddressstartswithfile:///;2.SecurityrestrictionsblockAJAX,localStorage,andcross-folderaccessonfile://;usealocalserverlikepython-mhttp.server8000tor

了解網(wǎng)絡(luò)端口和防火牆 了解網(wǎng)絡(luò)端口和防火牆 Aug 01, 2025 am 06:40 AM

NetworkPortSandFireWallsworkTogetHertoEnableCommunication whereSeringSecurity.1.NetWorkPortSareVirtualendPointSnumbered0-655 35,with-Well-with-Newonportslike80(HTTP),443(https),22(SSH)和25(smtp)sindiessingspefificservices.2.portsoperateervertcp(可靠,c

比較Java框架:Spring Boot vs Quarkus vs Micronaut 比較Java框架:Spring Boot vs Quarkus vs Micronaut Aug 04, 2025 pm 12:48 PM

前形式攝取,quarkusandmicronautleaddueTocile timeProcessingandGraalvSupport,withquarkusoftenpernperforminglightbetterine nosserless notelless centarios.2。

See all articles