欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java基礎(chǔ)之詳細總結(jié)五種常用運算符

 更新時間:2021年05月21日 10:17:37   作者:香菜聊游戲  
在通常代碼邏輯處理中,我們常常都會使用到運算符,今天我們就詳細了解一下運算符的使用以及分類.運算符是對常量或者變量進行操作的符號,它分為算術(shù)運算符,賦值運算符,比較運算符,邏輯運算符以及位運算符.需要的朋友可以參考下

一、算術(shù)運算符

算術(shù)運算符的符號通常為:加(+)、減(-)、乘(*)、除(/)、取余(%)、自增(++)、自減(--)。

使用int類型的變量和int類型的變量做除法,得到的結(jié)果還是int類型;

使用double類型的常量和 int類型的常量做除法,會得到double類型的結(jié)果;在使用強制類型double轉(zhuǎn)換可以得到double類型

System.out.println(7 / 2);//3.0
System.out.println((double)(7 / 2));  // 3.0
System.out.println((double)7 / 2);    // 3.5

既然存在除法,那么對于除0這個特殊的數(shù),Java的程序是怎么處理的呢,是否都是異常的報錯呢?我們可以執(zhí)行試一下

// 產(chǎn)生異常:java.lang.ArithmeticException: / by zero
 
int i = 123 / 0;
 
System.out.println(i);
 
 
 
// 產(chǎn)生異常:java.lang.ArithmeticException: / by zero
 
int j = 0 / 0;
 
System.out.println(j);
 
 
 
double k = 123.45 / 2;
 
System.out.println(k); // 61.725
 
 
 
double x = 123.45 / 0;
 
System.out.println(x); // Infinity(正無窮大)
 
 
 
double y = -123.45 / 0;
 
System.out.println(y); // -Infinity(負無窮大)
 
 
 
double m = 0.0 / 0;
 
System.out.println(m); // NaN(Not a number 不是一個數(shù))
 
 
 
double n = -0.0 / 0;
 
System.out.println(n); // NaN(Not a number 不是一個數(shù))
 
 
 
float x = 123.45F / 0;
 
System.out.println(x); // Infinity(正無窮大)
 
 
 
float y = -123.45F / 0;
 
System.out.println(y); // -Infinity(負無窮大)
 
 
 
float m = 0.0F / 0;
 
System.out.println(m); // NaN(Not a number 不是一個數(shù))
 
 
 
float n = -0.0F / 0;
 
System.out.println(n); // NaN(Not a number 不是一個數(shù))
 
 
 
//產(chǎn)生異常:java.lang.ArithmeticException: / by zero
 
int x = 11 % 0;
 
System.out.println(x);
 
 
 
double y = 11.0 % 0;
 
System.out.println(y); // NaN

自增運算符

單獨使用自增運算符:不論++放在需要自增的變量的前面還是后面,都會在操作后讓變量的值自增1

非單獨使用自增運算符:int j = i++; // i: 3 j: 2(一上來先把i的值賦值給j,然后i自己做自增(先賦值再自增));int j = ++i; // i: 3 j: 3(上來先i自己做自增,然后把i的值(自增后的值)賦值給j(先自增再賦值));

這里附加一個練習題:

int i = 2;
 
int j = 3;
 
j = i++ + ++i+i*6;

最后j是多少?(結(jié)果是:30)

二、賦值運算符

賦值運算符:=、+=、-=、*=、/=、%=

這個沒什么說的只是進行賦值的操作,只是要注意對于非默認數(shù)據(jù)類型的數(shù)據(jù),使用帶有算術(shù)運算符的賦值運算符時,會自動進行強制類型轉(zhuǎn)換,例如:

byte j = 5;j += 6; // 下句等價于上句 j = (byte) (j + 6);

三、比較運算符

比較運算符:==、!=、>、<、>=、<=;Java中使用 == 表示相等(內(nèi)容相等)

四、邏輯運算符

邏輯運算符:&、|、!、^、&&、||

&:邏輯與,有一個是false得到的結(jié)果就是false

|:邏輯或,有一個是true得到的結(jié)果就是true

!:邏輯非,顛倒黑白

^:邏輯異或,類似吸鐵石(真假為真,真真為假,假假為假)

&&:邏輯與,如果參與運算的第一個變量或表達式為false,得到的結(jié)果就是false,其他的變量或表達式就不去執(zhí)行;如果多個邏輯與參與運算,以此類推; ||:邏輯或,如果參與運算的第一個變量或表達式為true,得到的結(jié)果就是true,其他的變量或表達式就不去執(zhí)行;如果多個邏輯與參與運算,以此類推;

&和&&區(qū)別:&&具有短路的操作,比如第一個表達式是false時,是不會執(zhí)行第二個表達式(if(s!=null&&s.equal(""))),如果s是null的話使用&就會報錯;&可以可以用在位運算符中。

練習題:

int i = 2;
 
int j = 3;
 
System.out.println((++i == 2) && (j++ == 3));

問:最終i 和 j 的值是多少?(i為3,j為3)

int i = 2;
 
int j = 3;
 
System.out.println((++i == 2) & (j++ == 3));

問:最終i 和 j 的值是多少?(i為3,j為4)

五、位運算符

位運算符:&、|、~、^、>>、>>>、<<

規(guī)則:(在二進制中)操作的是補碼

&:位與,進行操作的兩個數(shù)的同一位上,有一個是0,該位運算的結(jié)果就是0

|:位或,進行操作的兩個數(shù)的同一位上,有一個是1,該位運算的結(jié)果就是1

~:位非,進行操作的數(shù)按位取反

^:位異或,進行操作的兩個數(shù)的同一位上,兩個相同為0,兩個不同為1(規(guī)律:一個數(shù)連續(xù)兩次和另一個數(shù)做位異或運算,得到其本身的值)

System.out.println(2 & 3); // 2
 
 
 
System.out.println(2 | 3); // 3
 
 
 
System.out.println(~2); // -3
 
 
 
System.out.println(2 ^ 3); // 1
 
 
 
System.out.println(2 ^ 3 ^ 3); // 2
 
 
 
/*
* 2:0000 0010
* 3:0000 0011
*
* 2
* 原碼:0000 0000 0000 0000 0000 0000 0000 0010
* 反碼:0000 0000 0000 0000 0000 0000 0000 0010
* 補碼:0000 0000 0000 0000 0000 0000 0000 0010
*
* ~2
* 補碼:1111 1111 1111 1111 1111 1111 1111 1101
* 反碼:1111 1111 1111 1111 1111 1111 1111 1100
* 原碼:1000 0000 0000 0000 0000 0000 0000 0011
*/

<<:左移,左邊的高位刪除,右邊的低位補0

>>:右移,因為左側(cè)的最高位是符號位,所以要區(qū)分是0還是1;左側(cè)的最高位是0,左側(cè)補0;左側(cè)的最高位是1,左側(cè)補1 >>>:無符號右移,不論左側(cè)的最高位是0還是1,左側(cè)補0

System.out.println(2 << 1); // 4
 
 
 
System.out.println(2 >> 1); // 1
 
 
 
System.out.println(-2 >> 1); // -1
 
 
 
System.out.println(-2 >>> 1); // 2147483647
 
 
 
/*
* -2:
* 原碼:1000 0000 0000 0000 0000 0000 0000 0010
* 反碼:1111 1111 1111 1111 1111 1111 1111 1101
* 補碼:1111 1111 1111 1111 1111 1111 1111 1110
*
* 右移1位操作(操作補碼)
*
* 補碼:1111 1111 1111 1111 1111 1111 1111 1111
* 反碼:1111 1111 1111 1111 1111 1111 1111 1110
* 原碼:1000 0000 0000 0000 0000 0000 0000 0001
*
* 無符號右移1位操作(操作補碼)
*
* 補碼:0111 1111 1111 1111 1111 1111 1111 1111
* 反碼:0111 1111 1111 1111 1111 1111 1111 1111
* 原碼:0111 1111 1111 1111 1111 1111 1111 1111
*/
 

到此這篇關(guān)于Java基礎(chǔ)之詳細總結(jié)五種運算符的文章就介紹到這了,更多相關(guān)Java五種運算符內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java解析xml的四種方法匯總

    Java解析xml的四種方法匯總

    XML在不同的語言里解析方式都是一樣的,只不過實現(xiàn)的語法不同而已。java中基本的解析方式有四種,DOM解析、sax解析、JDOM解析和DOM4J解析,下面我們就來詳細探討下這四種方式
    2016-05-05
  • java 線程方法join簡單用法實例總結(jié)

    java 線程方法join簡單用法實例總結(jié)

    這篇文章主要介紹了java 線程方法join簡單用法,結(jié)合實例形式總結(jié)分析了Java線程join方法的功能、原理及使用技巧,需要的朋友可以參考下
    2019-11-11
  • Java 10 局部變量類型推斷淺析

    Java 10 局部變量類型推斷淺析

    這篇文章主要介紹了Java 10 局部變量類型推斷淺析,Java 10 引進一種新的閃閃發(fā)光的特性叫做局部變量類型推斷。文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,,需要的朋友可以參考下
    2019-06-06
  • 關(guān)于Java的動態(tài)代理機制

    關(guān)于Java的動態(tài)代理機制

    這篇文章主要介紹了關(guān)于Java的動態(tài)代理機制,動態(tài)代理就是,在程序運行期,創(chuàng)建目標對象的代理對象,并對目標對象中的方法進行功能性增強的一種技術(shù),需要的朋友可以參考下
    2023-05-05
  • Java實現(xiàn)后端跨域的常見解決方案

    Java實現(xiàn)后端跨域的常見解決方案

    跨源資源共享(CORS——Cross-Origin Resource Sharing,跨源資源共享,或通俗地譯為跨域資源共享)是一種基于 HTTP 頭的機制,跨域的解決方案有很多種,前后端都有,本文給大家主要介紹Java實現(xiàn)后端跨域的常見解決方案,需要的朋友可以參考下
    2024-04-04
  • Java?Spring讀取和存儲詳細操作

    Java?Spring讀取和存儲詳細操作

    這篇文章主要介紹了Spring讀取和存儲詳細操作,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-08-08
  • java實現(xiàn)Dijkstra最短路徑算法

    java實現(xiàn)Dijkstra最短路徑算法

    這篇文章主要為大家詳細介紹了java實現(xiàn)Dijkstra最短路徑算法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • 使用java實現(xiàn)http多線程斷點下載文件(一)

    使用java實現(xiàn)http多線程斷點下載文件(一)

    Java 多線程斷點下載文件基本原理:利用URLConnection獲取要下載文件的長度、頭部等相關(guān)信息,并設(shè)置響應的頭部信息,本文將詳細介紹,需要了解更多的朋友可以參考下
    2012-12-12
  • Java中的遞增i++與++i的實現(xiàn)原理詳解

    Java中的遞增i++與++i的實現(xiàn)原理詳解

    這篇文章主要介紹了Java中的i++與++i的實現(xiàn)原理詳解,在Java中,i++是一種常見的遞增操作符,用于將變量i的值增加1,它是一種簡潔且方便的方式來實現(xiàn)循環(huán)和計數(shù)功能,i++可以用于各種情況,本文來看一下其實現(xiàn)原理,需要的朋友可以參考下
    2023-10-10
  • SpringCloud?Eureka服務(wù)注冊中心應用入門詳解

    SpringCloud?Eureka服務(wù)注冊中心應用入門詳解

    這篇文章主要介紹了Spring?Cloud?Eureka服務(wù)注冊中心入門流程分析,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-07-07

最新評論