国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

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

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

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

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

我們知道程序中的所有數(shù)在計(jì)算機(jī)內(nèi)存中都是以二進(jìn)制的形式儲存的,而位運(yùn)算就是直接對整數(shù)在內(nèi)存中的二進(jìn)制位進(jìn)行操作。比如,and運(yùn)算本來是一個(gè)邏輯運(yùn)算符,但整數(shù)與整數(shù)之間也可以進(jìn)行and運(yùn)算。

位運(yùn)算主要有移位運(yùn)算和邏輯運(yùn)算。下面我們就分別來講講移位運(yùn)算和邏輯運(yùn)算。

移位運(yùn)算:

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

例如:

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

邏輯運(yùn)算有:

  • 按位與 &:兩位都為1才為1

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

  • 按位取反 ~: 1變?yōu)?,0變?yōu)?

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

例如:

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

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

場景一:判斷奇偶

分析:奇數(shù)都不是2的整數(shù)倍,轉(zhuǎn)換成二進(jìn)制后最低位必然為1,偶數(shù)則相反。利用這個(gè)特性我們可以很容易的通過位運(yùn)算判斷一個(gè)整數(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ù)");
    }

場景二:判斷一個(gè)正整數(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

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

(學(xué)習(xí)視頻分享:java視頻教程

場景三:簡單的集合處理

不廢話,直接看代碼:

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

好的,沒有問題。

大家可能會覺得,上面的示例代碼中的A、B、C、D有點(diǎn)類似于枚舉,事實(shí)上jdk源碼中的關(guān)于枚舉的集合類EnumSet使用的就是類似的方案,當(dāng)然比這個(gè)復(fù)雜得多,有興趣的可以去翻一下源碼,這個(gè)方案它有個(gè)名字,叫位向量。

順便提一句,java中int的包裝類Integer里面有很多靜態(tài)工具方提供位運(yùn)算操作,且大都十分復(fù)雜,感興趣的可以去看看

結(jié)語:

位運(yùn)算是計(jì)算機(jī)最擅長的運(yùn)算,jdk的源碼中也大量地使用了它,搞明白它有助于我們更加深入的理解計(jì)算機(jī),也有助于我們寫出更優(yōu)雅的代碼。?

相關(guān)推薦:java入門教程

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

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

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣服圖片

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

用于從照片中去除衣服的在線人工智能工具。

Clothoff.io

Clothoff.io

AI脫衣機(jī)

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智能換臉工具輕松在任何視頻中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的代碼編輯器

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 教程
1601
29
PHP教程
1502
276
如何使用JDBC處理Java的交易? 如何使用JDBC處理Java的交易? Aug 02, 2025 pm 12:29 PM

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

了解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

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

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

比較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。

了解網(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工作? 垃圾收集如何在Java工作? Aug 02, 2025 pm 01:55 PM

Java的垃圾回收(GC)是自動管理內(nèi)存的機(jī)制,通過回收不可達(dá)對象釋放堆內(nèi)存,減少內(nèi)存泄漏風(fēng)險(xiǎn)。1.GC從根對象(如棧變量、活動線程、靜態(tài)字段等)出發(fā)判斷對象可達(dá)性,無法到達(dá)的對象被標(biāo)記為垃圾。2.基于標(biāo)記-清除算法,標(biāo)記所有可達(dá)對象,清除未標(biāo)記對象。3.采用分代收集策略:新生代(Eden、S0、S1)頻繁執(zhí)行MinorGC;老年代執(zhí)行較少但耗時(shí)較長的MajorGC;Metaspace存儲類元數(shù)據(jù)。4.JVM提供多種GC器:SerialGC適用于小型應(yīng)用;ParallelGC提升吞吐量;CMS降

比較Java構(gòu)建工具:Maven vs. Gradle 比較Java構(gòu)建工具:Maven vs. Gradle Aug 03, 2025 pm 01:36 PM

Gradleisthebetterchoiceformostnewprojectsduetoitssuperiorflexibility,performance,andmoderntoolingsupport.1.Gradle’sGroovy/KotlinDSLismoreconciseandexpressivethanMaven’sverboseXML.2.GradleoutperformsMaveninbuildspeedwithincrementalcompilation,buildcac

以身作則,解釋說明 以身作則,解釋說明 Aug 02, 2025 am 06:26 AM

defer用于在函數(shù)返回前執(zhí)行指定操作,如清理資源;參數(shù)在defer時(shí)立即求值,函數(shù)按后進(jìn)先出(LIFO)順序執(zhí)行;1.多個(gè)defer按聲明逆序執(zhí)行;2.常用于文件關(guān)閉等安全清理;3.可修改命名返回值;4.即使發(fā)生panic也會執(zhí)行,適合用于recover;5.避免在循環(huán)中濫用defer,防止資源泄漏;正確使用可提升代碼安全性和可讀性。

See all articles