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

Java的基本數(shù)據(jù)類型和運算方法(必看篇)

 更新時間:2017年07月17日 08:55:46   投稿:jingxian  
下面小編就為大家?guī)硪黄狫ava的基本數(shù)據(jù)類型和運算方法(必看篇)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

編碼

ASCII--0~127 65-A 97-a

西歐碼表---ISO-8859-1---0-255---1個字節(jié)

gb2312----0-65535---gbk---2個字節(jié)

Unicode編碼體系---utf-8---3個字節(jié)

中 f

bit位 Byte字節(jié) 1Byte = 8bit 1KB=1024B MB GB TB PB---計算機中存儲單位

常量

整數(shù)常量---所有的整數(shù) 3,99,107

小數(shù)常量---所有的小數(shù) 3.5 100.9

字符常量---用單引號將一個字母、數(shù)字、符號標(biāo)識起來 ‘a(chǎn)' ‘=' ‘ '

字符串常量---用雙引號將一個或者多個字符標(biāo)識起來 “abc” “234” “q2” “”

布爾常量---用于表示邏輯值---true/false

空常量---null

5-整數(shù), 5.0-小數(shù) ‘5'-字符 “5”-字符串 ‘5.0'-寫法錯誤 “5.0”-字符串

進(jìn)制

二進(jìn)制:滿二進(jìn)一,0~1 1+1=10 0b10011 0b0011,從JDK1.7開始,允許以0b作為開頭來標(biāo)識一個數(shù)字是一個二進(jìn)制數(shù)字

八進(jìn)制:滿八進(jìn)一,0~7, 7+1=10 要求必須以0作為開頭 06 015

十進(jìn)制:滿十進(jìn)一,0~9

十六進(jìn)制:滿十六進(jìn)一,0~9,,A~F,9+1=A f+1=10 要求以0x作為開頭 0x5 0xad

進(jìn)制的轉(zhuǎn)換

十進(jìn)制轉(zhuǎn)換成二進(jìn)制:不斷除以2取余,然后將余數(shù)倒排

二進(jìn)制轉(zhuǎn)換成十進(jìn)制:從低位次起,按位次乘以2的位次次冪,然后求和

二進(jìn)制轉(zhuǎn)換成八進(jìn)制:從低位次起,每三位劃分為一組,不足三位補0,產(chǎn)生一位八進(jìn)制數(shù)字,將這些數(shù)字按序排列即可

八進(jìn)制轉(zhuǎn)換成二進(jìn)制:一變?nèi)?--一位八進(jìn)制數(shù)字產(chǎn)生三位二進(jìn)制數(shù)字

二進(jìn)制轉(zhuǎn)換成十六進(jìn)制:四變一的過程

變量

System.out.println(i);

int i = 5;---不行---變量必須先聲明在使用

int i;

System.out.println(i);---不行----變量在使用之前必須先初始化

數(shù)據(jù)類型

基本數(shù)據(jù)類型

數(shù)值型

整數(shù)型

byte---字節(jié)型---1個字節(jié)--- -2^7~2^7-1 --- -128~127

byte b = 5; byte b2 = -128;

short---短整型---2個字節(jié)--- -2^15~2^15-1 --- -32768~32767

short s = 54; short s = -900;

int---整型---4個字節(jié)--- -2^31~2^31-1

int i = 100000;

int j = 100_000_000;--從JDK1.7開始是允許的。在編譯的時候會自動忽略這些_ -> int j = 100000000;

int i = 00001111;---八進(jìn)制

Java中整數(shù)默認(rèn)類型就是int

long---長整型---8個字節(jié)--- -2^63~2^63-1---以L作為結(jié)尾標(biāo)識這個數(shù)字是一個long類型的數(shù)字

long l = 3L;

浮點型

float---單精度---4個字節(jié)---必須以f作為結(jié)尾

float f = 3.2f;

double---雙精度---8個字節(jié)

Java中小數(shù)默認(rèn)是double類型

double d = 3.5;

double d = 4.6D;---可以

double d = 3.9e4; //是十進(jìn)制的科學(xué)計數(shù)法

double d = 0x3p2; //是十六進(jìn)制的科學(xué)計數(shù)法 -> 12

字符型

char---2個字節(jié)--- 0 ~65535

char c = ‘a(chǎn)';

char c = ‘中';

布爾型

boolean---true/false

boolean b = false;

引用數(shù)據(jù)類型

類---class 接口---interface 數(shù)組---[]

數(shù)據(jù)類型的轉(zhuǎn)換

隱式轉(zhuǎn)換/自動類型轉(zhuǎn)換

byte b = 100;

int i = b;

long l = 63;---可以---當(dāng)整數(shù)的值在int類型的范圍內(nèi)的時候,可以不用添加L這個結(jié)尾

規(guī)律一:小的類型可以轉(zhuǎn)化為大的類型---byte->short->int->long float->double

int i = 5;

float f = i;

long l = 6;

float f = l;

規(guī)律二:整數(shù)可以轉(zhuǎn)化為小數(shù),但是可能產(chǎn)生精度損失

char c = ‘a(chǎn)';

int i = c;

規(guī)律三:字符型可以轉(zhuǎn)化為整型

short s = ‘a(chǎn)';---可以

char c = 100;---可以

char c = ‘a(chǎn)';

short s = c;---不可以

定義了char類型的變量c,存儲的數(shù)據(jù)是一個字符,不需要檢查具體的字符編碼,當(dāng)賦值給short類型的時候,short需要檢查這個字符對應(yīng)的編碼是否在short類型的取值范圍內(nèi),這個時候無法確定這個字符對應(yīng)的具體編碼,由于short類型的取值范圍和char類型沒有完全重合,為了防止出現(xiàn)超過范圍的情況,不允許賦值。

short s = 97;

char c = s;--不可以

顯式轉(zhuǎn)換/強制類型轉(zhuǎn)換

long l = 54;

int i = (int)l;

double d = 3.5;

int i = (int)d;---小數(shù)強轉(zhuǎn)成整數(shù)的時候,小數(shù)部分直接舍棄

double類型不能精確存儲小數(shù)

Hexadecimal--十六進(jìn)制

Decimal--十進(jìn)制

Octal---八進(jìn)制

Binary--二進(jìn)制

運算符

算術(shù)運算符

+加 -減 *乘 /除 %取模 ++自增 --自減 +字符串拼接

int i = 5210 / 1000 * 1000;--->i = 5000;

注意:

1. 整數(shù)運算完成之后結(jié)果一定是整數(shù)

2. 整數(shù)除以0的時候,編譯通過,運行報錯---ArimeticException---算術(shù)異常

3. 小數(shù)除以0的結(jié)果是Infinity

4. 0/0.0的結(jié)果是NaN---Not a Number---非數(shù)字

5. byte/short類型在運算的時候會自動提升為int類型

%取余運算

-5%3=-2 -4%3=-1 -3%7=-3

5%-3=2 7%-2=1 2%-8=2

-5%-3=-2 -9%-3=0

對于負(fù)數(shù)的取余,先按照正數(shù)的取余運算,看取余符號左邊的數(shù)字的符號,如果左邊是負(fù)數(shù),那么結(jié)果就是負(fù)數(shù)

5%1.2=0.2 6%1.3=0.8

4.3%1.4=0.1

++/--

對于++在原來的基礎(chǔ)上自增1

int i = 5;

int j = ++i;---> i自增1,然后將i的值賦值給j---先自增,再運算

int j = i++;--->先獲取i的值5,i自增變成6,然后將獲取的值5賦值給j---先運算,再自增

int i = 3;

int j = ++i * 2;-> j = 8;

int j = i++ * 2;->j = 6

int i = 6;

int j = i++ + ++i;->i = 8; j = 14;

int j = ++i + i++;->i = 8; j = 14

byte b = 5;

b++;---JVM在底層會對結(jié)果進(jìn)行強制類型轉(zhuǎn)換,將結(jié)果再轉(zhuǎn)換為byte類型

char c = ‘a(chǎn)';

System.out.println(c + 4);--可以

char c2 = ‘d';

System.out.println(c + c2);---提升為int類型之后再進(jìn)行運算

+ 字符串拼接運算

“a” + “b”---> “ab”

“a” + 3---> “a3”

“a” + true-> “atrue”

2 + 4 + “f”-> “6f”

“f” + 2 + 4-> “f24”

賦值運算符

= += -= *= /= %= &= |= ^= <<= >>= >>>= ~=

int i= 5;

i += 3; -> i = i + 3; -> i = 8;

i -= 2;-> i = i - 2;-> i = 3;

int j;

j += 4;---不行

int i = 5;

i += i -= i *= 5;--> i = -15;

i = 5 + ( 5 - (5 * 5)) ;

i += i -= i *= ++i;--->i = -20;

i += i*= i-= (i++ + --i);---> i = -20;

i = 5 + ( 5 * (5 - (5 + 5)));

byte b = 5;

b += 3;---可以

byte b = 125;

b += 3;---可以--- -128

比較/關(guān)系運算符

==相等 !=不等 > < >= <= instanceof

3 == 4;-> false

instanceof---判斷對象與類的關(guān)系的--只能用于引用數(shù)據(jù)類型

String s = “abd”;

System.out.println(s instanceof String);---true

System.out.println(“def” instanceof String);---true

邏輯運算符

用于運算邏輯值

&與 |或 !非 ^異或 &&短路與 ||短路或

true&true=true true&false=false false&true=false false&false=false

true|true=true true|false=true false|true=true false|false=false

!true=false !false=true

true^true=false true^false=true false^true=true false^false=false

對于&&,如果前一個表達(dá)式的值為false,那么就能確定整個表達(dá)式的值為false,&&后邊的運算就不再進(jìn)行了

三元/三目/條件運算符

邏輯值?表達(dá)式1:表達(dá)式2

如果邏輯值為true,執(zhí)行表達(dá)式1;反之執(zhí)行表達(dá)式2

int i = 5, j = 7;

i > j ? System.out.println(i): System.out.println(j);---不行!三元運算符運算完成之后必須有結(jié)果!

double d = i > j ? i * 2.5 : j;---兩個表達(dá)式的返回值類型要么一致,要么相容

從控制臺獲取數(shù)據(jù)

import java.util.Scanner; //寫在package之下,class 之上

Scanner s = new Scanner(System.in);

int i = s.nextInt();

double d = s.nextDouble();

String str = s.nextLine();

String str2 = s.next();

以上這篇Java的基本數(shù)據(jù)類型和運算方法(必看篇)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java中CAS機制實現(xiàn)方法詳解

    Java中CAS機制實現(xiàn)方法詳解

    傳統(tǒng)的并發(fā)控制手段如synchronized和ReentrantLock雖有效防止資源競爭,卻可能引起性能開銷,相比之下,CAS(CompareAndSwap)提供一種輕量級的樂觀鎖策略,通過硬件級別的原子指令實現(xiàn)無鎖并發(fā),提高性能,需要的朋友可以參考下
    2024-09-09
  • Java中BigDecimal的加減乘除、比較大小與使用注意事項

    Java中BigDecimal的加減乘除、比較大小與使用注意事項

    對于不需要任何準(zhǔn)確計算精度的數(shù)字可以直接使用float或double,但是如果需要精確計算的結(jié)果,則必須使用BigDecimal類,而且使用BigDecimal類也可以進(jìn)行大數(shù)的操作,下面這篇文章給大家介紹了Java中BigDecimal的加減乘除、比較大小與使用注意事項,需要的朋友可以參考下。
    2017-11-11
  • spring/springboot整合curator遇到的坑及解決

    spring/springboot整合curator遇到的坑及解決

    這篇文章主要介紹了spring/springboot整合curator遇到的坑及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • Intellij IDEA 熱部署處理方法(圖解)

    Intellij IDEA 熱部署處理方法(圖解)

    本文通過圖文并茂的形式給大家介紹了Intellij IDEA 熱部署處理方法,需要的朋友可以參考下
    2018-02-02
  • 踩坑之spring事務(wù),非事務(wù)方法與事務(wù)方法執(zhí)行相互調(diào)用方式

    踩坑之spring事務(wù),非事務(wù)方法與事務(wù)方法執(zhí)行相互調(diào)用方式

    這篇文章主要介紹了踩坑之spring事務(wù),非事務(wù)方法與事務(wù)方法執(zhí)行相互調(diào)用方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • Java ArrayList與Vector和LinkedList的使用及源碼分析

    Java ArrayList與Vector和LinkedList的使用及源碼分析

    ArrayList、Vector、LinkedList類均在java.util包中,均為可伸縮數(shù)組,即可以動態(tài)改變長度的數(shù)組。ArrayList 和 Vector都是基于存儲元素的Object[] array來實現(xiàn)的,它們會在內(nèi)存中開辟一塊連續(xù)的內(nèi)存來存儲
    2022-11-11
  • 在Java的MyBatis框架中建立接口進(jìn)行CRUD操作的方法

    在Java的MyBatis框架中建立接口進(jìn)行CRUD操作的方法

    這篇文章主要介紹了在Java的MyBatis框架中建立接口進(jìn)行CRUD操作的方法,CRUD是指在做計算處理時的增加(Create)、重新取得數(shù)據(jù)(Retrieve)、更新(Update)和刪除(Delete)幾個單詞的首字母簡寫,需要的朋友可以參考下
    2016-04-04
  • 使用Netty快速實現(xiàn)一個群聊功能的示例詳解

    使用Netty快速實現(xiàn)一個群聊功能的示例詳解

    這篇文章主要為大家詳細(xì)介紹了如何利用?Netty?框架開發(fā)一個?WebSocket?服務(wù)端,從而實現(xiàn)一個簡單的在線聊天功能,感興趣的小伙伴可以了解下
    2023-11-11
  • Java流式操作之Collectors工具類操作指南

    Java流式操作之Collectors工具類操作指南

    Collectors是Collector的工具類,類中提供了很多流收集、歸約、分組、分區(qū)等方法,方便我們直接使用,下面這篇文章主要給大家介紹了關(guān)于Java流式操作之Collectors工具類操作的相關(guān)資料,需要的朋友可以參考下
    2023-05-05
  • Java設(shè)計模塊系列之書店管理系統(tǒng)單機版(三)

    Java設(shè)計模塊系列之書店管理系統(tǒng)單機版(三)

    這篇文章主要為大家詳細(xì)介紹了Java單機版的書店管理系統(tǒng)設(shè)計模塊和思想第三章,感興趣的小伙伴們可以參考一下
    2016-08-08

最新評論