真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Java關(guān)鍵字和保留字是什么-創(chuàng)新互聯(lián)

這篇文章主要講解了“Java關(guān)鍵字和保留字是什么”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“Java關(guān)鍵字和保留字是什么”吧!

成都創(chuàng)新互聯(lián)公司基于成都重慶香港及美國等地區(qū)分布式IDC機(jī)房數(shù)據(jù)中心構(gòu)建的電信大帶寬,聯(lián)通大帶寬,移動大帶寬,多線BGP大帶寬租用,是為眾多客戶提供專業(yè)成都服務(wù)器托管報價,主機(jī)托管價格性價比高,為金融證券行業(yè)服務(wù)器托管,ai人工智能服務(wù)器托管提供bgp線路100M獨(dú)享,G口帶寬及機(jī)柜租用的專業(yè)成都idc公司。

1、訪問控制

1) private 私有的

private 關(guān)鍵字是訪問控制修飾符,可以應(yīng)用于類、方法或字段(在類中聲明的變量)。 只能在聲明 private(內(nèi)部)類、方法或字段的類中引用這些類、方法或字段。在類的外部或者對于子類而言,它們是不可見的。

2) protected 受保護(hù)的

protected 關(guān)鍵字是可以應(yīng)用于類、方法或字段(在類中聲明的變量)的訪問控制修飾符??梢栽诼暶?protected 類、方法或字段的類、同一個包中的其他任何類以及任何子類(無論子類是在哪個包中聲明的)中引用這些類、方法或字段。

3) public 公共的

public 關(guān)鍵字是可以應(yīng)用于類、方法或字段(在類中聲明的變量)的訪問控制修飾符。 可能只會在其他任何類或包中引用 public 類、方法或字段。

那么我們總結(jié)一下,Java之中的權(quán)限訪問修飾符(其實(shí)還有一種權(quán)限訪問情況,就是默認(rèn)情況,暫且稱作default吧)。

2、類、方法和變量修飾符

1) abstract 聲明抽象

abstract關(guān)鍵字可以修改類或方法。abstract類可以擴(kuò)展(增加子類),但不能直接實(shí)例化。abstract方法不在聲明它的類中實(shí)現(xiàn),但必須在某個子類中重寫。采用 abstract方法的類本來就是抽象類,并且必須聲明為abstract。

2) class類

class 關(guān)鍵字用來聲明新的 Java 類,該類是相關(guān)變量和/或方法的集合。類是面向?qū)ο蟮某绦蛟O(shè)計方法的基本構(gòu)造單位。類通常代表某種實(shí)際實(shí)體,如幾何形狀或人。類是對象的模板。每個對象都是類的一個實(shí)例。要使用類,通常使用 new 操作符將類的對象實(shí)例化,然后調(diào)用類的方法來訪問類的功能。

3) extends 繼承、擴(kuò)展

extends 關(guān)鍵字用在 class 或 interface 聲明中,用于指示所聲明的類或接口是其名稱后跟有 extends 關(guān)鍵字的類或接口的子類。子類繼承父類的所有 public 和 protected 變量和方法(但是不包括構(gòu)造函數(shù))。 子類可以重寫父類的任何非 final 方法。一個類只能擴(kuò)展一個其他類。

extends 關(guān)鍵字用在 class 或 interface 聲明中,用于指示所聲明的類或接口是其名稱后跟有 extends 關(guān)鍵字的類或接口的子類。

4) final 最終、不可改變

在Java中,final關(guān)鍵字可以用來修飾類、方法和變量(包括成員變量和局部變量)。final方法在編譯階段綁定,稱為靜態(tài)綁定(static binding)。下面就從這四個方面來了解一下final關(guān)鍵字的基本用法。

修飾類

當(dāng)用final修飾一個類時,表明這個類不能被繼承,不能有子類。也就是說,如果一個類你永遠(yuǎn)不會讓他被繼承,就可以用final進(jìn)行修飾。final類中的成員變量可以根據(jù)需要設(shè)為final,但是要注意final類中的所有成員方法都會被隱式地指定為final方法。

修飾方法

使用final方法的原因有兩個。第一個原因是把方法鎖定,以防任何繼承類修改它的含義;第二個原因是效率。在早期的Java實(shí)現(xiàn)版本中,會將final方法轉(zhuǎn)為內(nèi)嵌調(diào)用。但是如果方法過于龐大,可能看不到內(nèi)嵌調(diào)用帶來的任何性能提升。在最近的Java版本中,不需要使用final方法進(jìn)行這些優(yōu)化了。

因此,如果只有在想明確禁止 該方法在子類中被覆蓋的情況下才將方法設(shè)置為final的。

還有就是,類的private方法會隱式地被指定為final方法。

修飾變量

修飾變量是final用得最多的地方。

對于一個final變量,如果是基本數(shù)據(jù)類型的變量,則其數(shù)值一旦在初始化之后便不能更改;如果是引用類型的變量,則在對其初始化之后便不能再讓其指向另一個對象。引用變量被final修飾之后,雖然不能再指向其他對象,但是它指向的對象的內(nèi)容是可變的。

final參數(shù)

當(dāng)函數(shù)參數(shù)為final類型時,你可以讀取使用該參數(shù),但是無法改變該參數(shù)的值或者引用指向。道理同final變量。

概括起來就是:

在A類是聲明為final類型的方法,那么不能在子類里被覆蓋;

如果A類被聲明為final類型的類,那么B類不能繼承A類;

如果成員變量聲明為final類型,那么成員變量不能被修改;

注意:

一個類不能同時是 abstract 又是 final。abstract 意味著必須擴(kuò)展類,final 意味著不能擴(kuò)展類。一個方法不能同時是 abstract 又是 final。abstract 意味著必須重寫方法,final 意味著不能重寫方法。兩者是相互矛盾的。

當(dāng)用final作用于類的成員變量時,成員變量(注意是類的成員變量,局部變量只需要保證在使用之前被初始化賦值即可)必須在定義時或者構(gòu)造器中進(jìn)行初始化賦值,而且final變量一旦被初始化賦值之后,就不能再被賦值了。

final變量和普通變量的區(qū)別。當(dāng)final變量是基本數(shù)據(jù)類型以及String類型時,如果在編譯期間能知道它的確切值,則編譯器會進(jìn)行優(yōu)化,會把它當(dāng)做編譯期常量使用。也就是說在用到該final變量的地方,相當(dāng)于直接訪問的這個常量,不需要在運(yùn)行時確定。這種和C語言中的宏替換有點(diǎn)像。而普通變量在編譯時,確定不了自身的值,需要在運(yùn)行時才能知道。

局部內(nèi)部類和匿名內(nèi)部類只能訪問局部final變量。因?yàn)檫@里的局部變量,需要在編譯階段便需要確定下來的。也就是說,如果局部變量的值在編譯期間就可以確定,則直接在匿名內(nèi)部里面創(chuàng)建一個拷貝。如果局部變量的值無法在編譯期間確定,則通過構(gòu)造器傳參的方式來對拷貝進(jìn)行初始化賦值。

5) implements實(shí)現(xiàn)

implements 關(guān)鍵字在 class 聲明中使用,以指示所聲明的類提供了在 implements 關(guān)鍵字后面的名稱所指定的接口中所聲明的所有方法的實(shí)現(xiàn)。類必須提供在接口中所聲明的所有方法的實(shí)現(xiàn)。一個類可以實(shí)現(xiàn)多個接口。

6) interface 接口

interface 關(guān)鍵字用來聲明新的 Java 接口,接口是方法的集合。

接口是 Java 語言的一項(xiàng)強(qiáng)大功能。任何類都可聲明它實(shí)現(xiàn)一個或多個接口,這意味著它實(shí)現(xiàn)了在這些接口中所定義的所有方法。

實(shí)現(xiàn)了接口的任何類都必須提供在該接口中的所有方法的實(shí)現(xiàn)。一個類可以實(shí)現(xiàn)多個接口。

7) native 本地

native 關(guān)鍵字可以應(yīng)用于方法,以指示該方法是用Java以外的語言實(shí)現(xiàn)的,方法對應(yīng)的實(shí)現(xiàn)不是在當(dāng)前文件,而是在用其他語言(如C和C++)實(shí)現(xiàn)的文件中。。

Java不是完美的,Java的不足除了體現(xiàn)在運(yùn)行速度上要比傳統(tǒng)的C++慢許多之外,Java無法直接訪問到操作系統(tǒng)底層(如系統(tǒng)硬件等),為此Java使用native方法來擴(kuò)展Java程序的功能。

可以將native方法比作Java程序同C程序的接口,其實(shí)現(xiàn)步驟:

在Java中聲明native()方法,然后編譯;

用javah產(chǎn)生一個.h文件;

寫一個.cpp文件實(shí)現(xiàn)native導(dǎo)出方法,其中需要包含第二步產(chǎn)生的.h文件(注意其中又包含了JDK帶的jni.h文件);

將第三步的.cpp文件編譯成動態(tài)鏈接庫文件;

在Java中用System.loadLibrary()方法加載第四步產(chǎn)生的動態(tài)鏈接庫文件,這個native()方法就可以在Java中被訪問了。

JAVA本地方法適用的情況

1、為了使用底層的主機(jī)平臺的某個特性,而這個特性不能通過JAVA API訪問

2、為了訪問一個老的系統(tǒng)或者使用一個已有的庫,而這個系統(tǒng)或這個庫不是用JAVA編寫的

3、為了加快程序的性能,而將一段時間敏感的代碼作為本地方法實(shí)現(xiàn)。

8) new 新,創(chuàng)建

new 關(guān)鍵字用于創(chuàng)建類的新實(shí)例。

new 關(guān)鍵字后面的參數(shù)必須是類名,并且類名的后面必須是一組構(gòu)造方法參數(shù)(必須帶括號)。 參數(shù)集合必須與類的構(gòu)造方法的簽名匹配。

= 賦值號左側(cè)的變量的類型必須與要實(shí)例化的類或接口具有賦值兼容關(guān)系。

9) static 靜態(tài)

static可以用于修飾屬性,可以修飾代碼塊,也可以用于修飾方法,還可以用于修飾類。

static修飾屬性:無論一個類生成了多少個對象,所有這些對象共同使用一份靜態(tài)的成員變量;一個對象對該靜態(tài)成員變量進(jìn)行了修改,其他對象的該靜態(tài)成員變量的值也會隨之發(fā)生變化。如果一個成員變量是static的,那么我們可以通過‘類名.成員變量名’的方式來使用它。

static修飾方法:static修飾的方法叫做靜態(tài)方法。對于靜態(tài)方法來說,可以使用‘類名.方法名’的方式來訪問。靜態(tài)方法只能繼承,不能重寫(Override),因?yàn)橹貙懯怯糜诒憩F(xiàn)多態(tài)的,重寫只能適用于實(shí)例方法,而靜態(tài)方法是可以不生成實(shí)例直接用類名來調(diào)用,這就會與重寫的定義所沖突,與多態(tài)所沖突,所以靜態(tài)方法不能重寫,只能是隱藏。

static方法與非static方法:不能在靜態(tài)方法中訪問非靜態(tài)成員變量;可以在靜態(tài)方法中訪問靜態(tài)的成員變量。可以在非靜態(tài)方法中訪問靜態(tài)的成員變量:因?yàn)殪o態(tài)方法可以直接用類名來調(diào)用,而非靜態(tài)成員變量是在創(chuàng)建對象實(shí)例時才為變量分配內(nèi)存和初始化變量值。

不能在靜態(tài)方法中使用this關(guān)鍵字:因?yàn)殪o態(tài)方法可以直接用類名來調(diào)用,而this實(shí)際上是創(chuàng)建實(shí)例時,實(shí)例對應(yīng)的一個應(yīng)用,所以不能在靜態(tài)方法上使用this。

static修飾代碼塊:靜態(tài)代碼塊。靜態(tài)代碼塊的作用也是完成一些初始化工作。**首先執(zhí)行靜態(tài)代碼塊,然后執(zhí)行構(gòu)造方法。**靜態(tài)代碼塊在類被加載的時候執(zhí)行,而構(gòu)造方法是在生成對象的時候執(zhí)行;要想調(diào)用某個類來生成對象,首先需要將類加載到Java虛擬機(jī)上(JVM),然后由JVM加載這個類來生成對象。

類的靜態(tài)代碼塊只會執(zhí)行一次,是在類被加載的時候執(zhí)行的,因?yàn)槊總€類只會被加載一次,所以靜態(tài)代碼塊也只會被執(zhí)行一次;而構(gòu)造方法則不然,每次生成一個對象的時候都會調(diào)用類的構(gòu)造方法,所以new一次就會調(diào)用構(gòu)造方法一次。如果繼承體系中既有構(gòu)造方法,又有靜態(tài)代碼塊,那么首先執(zhí)行最頂層的類的靜態(tài)代碼塊,一直執(zhí)行到最底層類的靜態(tài)代碼塊,然后再去執(zhí)行最頂層類的構(gòu)造方法,一直執(zhí)行到最底層類的構(gòu)造方法。注意:靜態(tài)代碼塊只會執(zhí)行一次。

static修飾類:這個有點(diǎn)特殊,首先,static是可以用來修飾類的,但是static是不允許用來修飾普通類,只能用來修飾內(nèi)部類,被static所修飾的內(nèi)部類可以用new關(guān)鍵字來直接創(chuàng)建一個實(shí)例,不需要先創(chuàng)建外部類實(shí)例。static內(nèi)部類可以被其他類實(shí)例化和引用(即使它是頂級類)。

其實(shí)理解起來也簡單。因?yàn)閟tatic主要是修飾類里面的成員,包括內(nèi)部類、屬性、方法這些。修飾這些變量的目的也很單純,那就是暗示這個成員在該類之中是的一份拷貝,即便是不斷的實(shí)例化該類,所有的這個類的對象都會共享這些static成員。這樣就好辦了。因?yàn)槭枪蚕淼摹⒌?,所以,也就不需要在?shí)例化這個類以后再通過這個類來調(diào)用這個成員了,顯然有點(diǎn)麻煩,所以就簡單一點(diǎn),直接通過類名直接調(diào)用static成員,更加直接。然而這樣設(shè)置之后,就出現(xiàn)了一個限制,就是,static方法之中不能訪問非static屬性,因?yàn)檫@個時候非static屬性可能還沒有給他分配內(nèi)存,該類還沒有實(shí)例化。

所以,通常,static 關(guān)鍵字意味著應(yīng)用它的實(shí)體在聲明該實(shí)體的類的任何特定實(shí)例外部可用。

可以從類的外部調(diào)用 static 方法,而不用首先實(shí)例化該類。這樣的引用始終包括類名作為方法調(diào)用的限定符。

10) strictfp 嚴(yán)格,精準(zhǔn)

strictfp的意思是FP-strict,也就是說精確浮點(diǎn)的意思。在Java虛擬機(jī)進(jìn)行浮點(diǎn)運(yùn)算時,如果沒有指定strictfp關(guān)鍵字時,Java的編譯器以及運(yùn)行環(huán)境在對浮點(diǎn)運(yùn)算的表達(dá)式是采取一種近似于我行我素的行為來完成這些操作,以致于得到的結(jié)果往往無法令人滿意。而一旦使用了strictfp來聲明一個類、接口或者方法時,那么所聲明的范圍內(nèi)Java的編譯器以及運(yùn)行環(huán)境會完全依照浮點(diǎn)規(guī)范IEEE-754來執(zhí)行。因此如果想讓浮點(diǎn)運(yùn)算更加精確,而且不會因?yàn)椴煌挠布脚_所執(zhí)行的結(jié)果不一致的話,那就請用關(guān)鍵字strictfp。

可以將一個類、接口以及方法聲明為strictfp,但是不允許對接口中的方法以及構(gòu)造函數(shù)聲明strictfp關(guān)鍵字。

11) synchronized線程、同步

synchronized 關(guān)鍵字可以應(yīng)用于方法或語句塊,并為一次只應(yīng)由一個線程執(zhí)行的關(guān)鍵代碼段提供保護(hù)。

synchronized 關(guān)鍵字可防止代碼的關(guān)鍵代碼段一次被多個線程執(zhí)行。

如果應(yīng)用于靜態(tài)方法,那么,當(dāng)該方法一次由一個線程執(zhí)行時,整個類將被鎖定。

如果應(yīng)用于實(shí)例方法,那么,當(dāng)該方法一次由一個線程訪問時,該實(shí)例將被鎖定。

如果應(yīng)用于對象或數(shù)組,當(dāng)關(guān)聯(lián)的代碼塊一次由一個線程執(zhí)行時,對象或數(shù)組將被鎖定。

一般的用法有:

synchronized 方法控制對類成員變量的訪問:每個類實(shí)例對應(yīng)一把鎖,

每個synchronized 方法都必須獲得調(diào)用該方法的類實(shí)例的鎖方能執(zhí)行,否則所屬線程阻塞,方法一旦執(zhí)行,就獨(dú)占該鎖,直到從該方法返回時才將鎖釋放,此后被阻塞的線程方能獲得該鎖,重新進(jìn)入可執(zhí)行狀態(tài)。這種機(jī)制確保了同一時刻對于每一個類實(shí)例,其所有聲明為 synchronized 的成員函數(shù)中至多只有一個處于可執(zhí)行狀態(tài)(因?yàn)橹炼嘀挥幸粋€能夠獲得該類實(shí)例對應(yīng)的鎖),從而有效避免了類成員變量的訪問沖突(只要所有可能訪問類成員變量的方法均被聲明為 synchronized)。

在Java中,不光是類實(shí)例,每一個類也對應(yīng)一把鎖,這樣我們也可將類的靜態(tài)成員函數(shù)聲明為 synchronized ,以控制其對類的靜態(tài)成員變量的訪問。

synchronized 方法的缺陷:若將一個大的方法聲明為synchronized 將會大大影響效率,典型地,若將線程類的方法 run() 聲明為synchronized ,由于在線程的整個生命期內(nèi)它一直在運(yùn)行,因此將導(dǎo)致它對本類任何synchronized 方法的調(diào)用都永遠(yuǎn)不會成功。當(dāng)然我們可以通過將訪問類成員變量的代碼放到專門的方法中,將其聲明為 synchronized ,并在主方法中調(diào)用來解決這一問題,但是 Java 為我們提供了更好的解決辦法,那就是 synchronized塊。

synchronized塊。

當(dāng)兩個并發(fā)線程訪問同一個對象object中的這個synchronized(this)同步代碼塊時,一個時間內(nèi)只能有一個線程得到執(zhí)行。另一個線程必須等待當(dāng)前線程執(zhí)行完這個代碼塊以后才能執(zhí)行該代碼塊。

然而,當(dāng)一個線程訪問object的一個synchronized(this)同步代碼塊時,另一個線程仍然可以訪問該object中的非synchronized(this)同步代碼塊。

尤其關(guān)鍵的是,當(dāng)一個線程訪問object的一個synchronized(this)同步代碼塊時,其他線程對object中所有其它synchronized(this)同步代碼塊的訪問將被阻塞。同樣適用其它同步代碼塊。也就是說,當(dāng)一個線程訪問object的一個synchronized(this)同步代碼塊時,它就獲得了這個object的對象鎖。結(jié)果,其它線程對該object對象所有同步代碼部分的訪問都被暫時阻塞。

這里的關(guān)鍵之處在于,這個object的對象鎖只有一把,一把鎖對應(yīng)一個線程。

12) transient 短暫

transient 關(guān)鍵字可以應(yīng)用于類的成員變量,以便指出該成員變量不應(yīng)在包含它的類實(shí)例已序列化時被序列化。

當(dāng)一個對象被串行化的時候,transient型變量的值不包括在串行化的表示中,然而非transient型的變量是被包括進(jìn)去的。

Java的serialization提供了一種持久化對象實(shí)例的機(jī)制。當(dāng)持久化對象時,可能有一個特殊的對象數(shù)據(jù)成員,我們不想用serialization機(jī)制來保存它。為了在一個特定對象的一個域上關(guān)閉serialization,可以在這個域前加上關(guān)鍵字transient。

transient是Java語言的關(guān)鍵字,用來表示一個域不是該對象串行化的一部分。當(dāng)一個對象被串行化的時候,transient型變量的值不包括在串行化的表示中,然而非transient型的變量是被包括進(jìn)去的。

13) volatile 易失

volatile 關(guān)鍵字用于表示可以被多個線程異步修改的成員變量。

注意:volatile 關(guān)鍵字在許多 Java 虛擬機(jī)中都沒有實(shí)現(xiàn)。 volatile 的目標(biāo)用途是為了確保所有線程所看到的指定變量的值都是相同的。

Volatile修飾的成員變量在每次被線程訪問時,都強(qiáng)迫從主內(nèi)存中重讀該成員變量的值。而且,當(dāng)成員變量發(fā)生變化時,強(qiáng)迫線程將變化值回寫到主內(nèi)存。這樣在任何時刻,兩個不同的線程總是看到某個成員變量的同一個值。

Java語言規(guī)范中指出:

為了獲得很好速度,允許線程保存共享成員變量的私有拷貝,而且只當(dāng)線程進(jìn)入或者離開同步代碼塊時才與共享成員變量的原始值對比。

這樣當(dāng)多個線程同時與某個對象交互時,就必須要注意到要讓線程及時的得到共享成員變量的變化。

而volatile關(guān)鍵字就是提示VM:對于這個成員變量不能保存它的私有拷貝,而應(yīng)直接與共享成員變量交互。

使用建議:在兩個或者更多的線程訪問的成員變量上使用volatile。當(dāng)要訪問的變量已在synchronized代碼塊中,或者為常量時,不必使用。

由于使用volatile屏蔽掉了VM中必要的代碼優(yōu)化,所以在效率上比較低,因此一定在必要時才使用此關(guān)鍵字。

Java 語言中的 volatile 變量可以被看作是一種 “程度較輕的 synchronized”;與 synchronized 塊相比,volatile 變量所需的編碼較少,并且運(yùn)行時開銷也較少,但是它所能實(shí)現(xiàn)的功能也僅是 synchronized 的一部分。

3、程序控制語句

1) break 跳出,中斷

break 關(guān)鍵字用于提前退出 for、while 或 do 循環(huán),或者在 switch 語句中用來結(jié)束 case 塊。

break 總是退出最深層的 while、for、do 或 switch 語句。

2) continue 繼續(xù)

continue 關(guān)鍵字用來跳轉(zhuǎn)到 for、while 或 do 循環(huán)的下一個迭代。

continue 總是跳到最深層 while、for 或 do 語句的下一個迭代。

3) return 返回

return 關(guān)鍵字會導(dǎo)致方法返回到調(diào)用它的方法,從而傳遞與返回方法的返回類型匹配的值。 如果方法具有非 void 的返回類型,return 語句必須具有相同或兼容類型的參數(shù)。 返回值兩側(cè)的括號是可選的。

4) do 運(yùn)行

do 關(guān)鍵字用于指定一個在每次迭代結(jié)束時檢查其條件的循環(huán)。

do 循環(huán)體至少執(zhí)行一次。 條件表達(dá)式后面必須有分號。

5) while 循環(huán)

while 關(guān)鍵字用于指定一個只要條件為真就會重復(fù)的循環(huán)。

6) if 如果

if 關(guān)鍵字指示有條件地執(zhí)行代碼塊。條件的計算結(jié)果必須是布爾值。

if 語句可以有可選的 else 子句,該子句包含條件為 false 時將執(zhí)行的代碼。

包含 boolean 操作數(shù)的表達(dá)式只能包含 boolean 操作數(shù)。

7) else 否則

else 關(guān)鍵字總是在 if-else 語句中與 if 關(guān)鍵字結(jié)合使用。else 子句是可選的,如果 if 條件為 false,則執(zhí)行該子句。

8) for 循環(huán)

for 關(guān)鍵字用于指定一個在每次迭代結(jié)束前檢查其條件的循環(huán)。

for 語句的形式為 for(initialize; condition; increment) 控件流進(jìn)入 for 語句時,將執(zhí)行一次 initialize 語句。 每次執(zhí)行循環(huán)體之前將計算 condition 的結(jié)果。如果 condition 為 true,則執(zhí)行循環(huán)體。

每次執(zhí)行循環(huán)體之后,在計算下一個迭代的 condition 之前,將執(zhí)行 increment 語句。

9) instanceof 實(shí)例

instanceof 關(guān)鍵字用來確定對象所屬的類。

10) switch 觀察

switch 語句用于基于某個表達(dá)式選擇執(zhí)行多個代碼塊中的某一個。

switch 條件的計算結(jié)果必須等于 byte、char、short 或 int。

case 塊沒有隱式結(jié)束點(diǎn)。break 語句通常在每個 case 塊末尾使用,用于退出 switch 語句。

如果沒有 break 語句,執(zhí)行流將進(jìn)入所有后面的 case 和/或 default 塊。

11) case 返回觀察里的結(jié)果

case 用來標(biāo)記 switch 語句中的每個分支。

case 塊沒有隱式結(jié)束點(diǎn)。break 語句通常在每個 case 塊末尾使用,用于退出 switch 語句。

如果沒有 break 語句,執(zhí)行流將進(jìn)入所有后面的 case 和/或 default 塊。

12) default 默認(rèn)

default 關(guān)鍵字用來標(biāo)記 switch 語句中的默認(rèn)分支。

default 塊沒有隱式結(jié)束點(diǎn)。break 語句通常在每個 case 或 default 塊的末尾使用,以便在完成塊時退出 switch 語句。

如果沒有 default 語句,其參數(shù)與任何 case 塊都不匹配的 switch 語句將不執(zhí)行任何操作。

4、錯誤處理

1) try 捕獲異常

try 關(guān)鍵字用于包含可能引發(fā)異常的語句塊。

每個 try 塊都必須至少有一個 catch 或 finally 子句。

如果某個特定異常類未被任何 catch 子句處理,該異常將沿著調(diào)用棧遞歸地傳播到下一個封閉 try 塊。如果任何封閉 try 塊都未捕獲到異常,Java 解釋器將退出,并顯示錯誤消息和堆棧跟蹤信息。

2) catch 處理異常

catch 關(guān)鍵字用來在 try-catch 或 try-catch-finally 語句中定義異常處理塊。

開始和結(jié)束標(biāo)記 { 和 } 是 catch 子句語法的一部分,即使該子句只包含一個語句,也不能省略這兩個標(biāo)記。 每個 try 塊都必須至少有一個 catch 或 finally 子句。

如果某個特定異常類未被任何 catch 子句處理,該異常將沿著調(diào)用棧遞歸地傳播到下一個封閉 try 塊。如果任何封閉 try 塊都未捕獲到異常,Java 解釋器將退出,并顯示錯誤消息和堆棧跟蹤信息。

3) throw 拋出一個異常對象

throw 關(guān)鍵字用于引發(fā)異常。

throw 語句將 java.lang.Throwable 作為參數(shù)。Throwable 在調(diào)用棧中向上傳播,直到被適當(dāng)?shù)?catch 塊捕獲。 引發(fā)非 RuntimeException 異常的任何方法還必須在方法聲明中使用 throws 修飾符來聲明它引發(fā)的異常。

4) throws 聲明一個異常可能被拋出

throws 關(guān)鍵字可以應(yīng)用于方法,以便指出方法引發(fā)了特定類型的異常。

throws 關(guān)鍵字將逗號分隔的 java.lang.Throwables 列表作為參數(shù)。

引發(fā)非 RuntimeException 異常的任何方法還必須在方法聲明中使用 throws 修飾符來聲明它引發(fā)的異常。 要在 try-catch 塊中包含帶 throws 子句的方法的調(diào)用,必須提供該方法的調(diào)用者。

5) finally

在異常處理機(jī)制當(dāng)中,它的作用就像是人吃飯一樣,必須得做的,不論有異常還是沒有異常都要執(zhí)行的代碼就可以放到finally塊當(dāng)中去。finally塊,必須要配合try塊一起使用,不能單獨(dú)使用,也不能直接和catch塊一起使用。

finally 關(guān)鍵字用來定義始終在 try-catch-finally 語句中執(zhí)行的塊。

finally 塊通常包含清理代碼,用在部分執(zhí)行 try 塊后恢復(fù)正常運(yùn)行。

5、包相關(guān)

1) import 引入

import 關(guān)鍵字使一個包中的一個或所有類在當(dāng)前 Java 源文件中可見??梢圆皇褂猛耆薅ǖ念惷麃硪脤?dǎo)入的類。

當(dāng)多個包包含同名的類時,許多 Java 程序員只使用特定的 import 語句(沒有“*”)來避免不確定性。

2) package 包

package 關(guān)鍵字指定在 Java 源文件中聲明的類所駐留的 Java 包。

package 語句(如果出現(xiàn))必須是 Java 源文件中的第一個非注釋性文本。 例:java.lang.Object。 如果 Java 源文件不包含 package 語句,在該文件中定義的類將位于“默認(rèn)包”中。請注意,不能從非默認(rèn)包中的類引用默認(rèn)包中的類。

6、基本類型

1) boolean 布爾型

boolean 是 Java 原始類型。boolean 變量的值可以是 true 或 false。

boolean 變量只能以 true 或 false 作為值。boolean 不能與數(shù)字類型相互轉(zhuǎn)換。

包含 boolean 操作數(shù)的表達(dá)式只能包含 boolean 操作數(shù)。

Boolean 類是 boolean 原始類型的包裝對象類。

2) byte 字節(jié)型

byte 是 Java 原始類型。byte 可存儲在 [-128, 127] 范圍以內(nèi)的整數(shù)值。

Byte 類是 byte 原始類型的包裝對象類。它定義代表此類型的值的范圍的 MIN_VALUE 和 MAX_VALUE 常量。 Java 中的所有整數(shù)值都是 32 位的 int 值,除非值后面有 l 或 L(如 235L),這表示該值應(yīng)解釋為 long。

3) char 字符型

char 是 Java 原始類型。char 變量可以存儲一個 Unicode 字符。

可以使用下列 char 常量:

\b - 空格, \f - 換頁, \n - 換行, \r - 回車, \t - 水平制表符, ’ - 單引號, " - 雙引號, \ - 反斜杠, \xxx - 采用 xxx 編碼的 Latin-1 字符。\x 和 \xx 均為合法形式,但可能引起混淆。 \uxxxx - 采用十六進(jìn)制編碼 xxxx 的 Unicode 字符。

Character 類包含一些可用來處理 char 變量的 static 方法,這些方法包括 isDigit()、isLetter()、isWhitespace() 和 toUpperCase()。

char 值沒有符號。

4) double 雙精度

double 是 Java 原始類型。double 變量可以存儲雙精度浮點(diǎn)值。

由于浮點(diǎn)數(shù)據(jù)類型是實(shí)際數(shù)值的近似值,因此,一般不要對浮點(diǎn)數(shù)值進(jìn)行是否相等的比較。

Java 浮點(diǎn)數(shù)值可代表無窮大和 NaN(非數(shù)值)。Double 包裝對象類用來定義常量 MIN_VALUE、MAX_VALUE、NEGATIVE_INFINITY、POSITIVE_INFINITY 和 NaN。

5) float 浮點(diǎn)

float 是 Java 原始類型。float 變量可以存儲單精度浮點(diǎn)值。

使用此關(guān)鍵字時應(yīng)遵循下列規(guī)則:

Java 中的浮點(diǎn)文字始終默認(rèn)為雙精度。要指定單精度文字值,應(yīng)在數(shù)值后加上 f 或 F,如 0.01f。

由于浮點(diǎn)數(shù)據(jù)類型是實(shí)際數(shù)值的近似值,因此,一般不要對浮點(diǎn)數(shù)值進(jìn)行是否相等的比較。

Java 浮點(diǎn)數(shù)值可代表無窮大和 NaN(非數(shù)值)。Float 包裝對象類用來定義常量 MIN_VALUE、MAX_VALUE、NEGATIVE_INFINITY、POSITIVE_INFINITY 和 NaN。

6) int 整型

int 是 Java 原始類型。int 變量可以存儲 32 位的整數(shù)值。

Integer 類是 int 原始類型的包裝對象類。它定義代表此類型的值的范圍的 MIN_VALUE 和 MAX_VALUE 常量。

Java 中的所有整數(shù)值都是 32 位的 int 值,除非值后面有 l 或 L(如 235L),這表示該值應(yīng)解釋為 long。

7) long 長整型

long 是 Java 原始類型。long 變量可以存儲 64 位的帶符號整數(shù)。

Long 類是 long 原始類型的包裝對象類。它定義代表此類型的值的范圍的 MIN_VALUE 和 MAX_VALUE 常量。

Java 中的所有整數(shù)值都是 32 位的 int 值,除非值后面有 l 或 L(如 235L),這表示該值應(yīng)解釋為 long。

8) short 短整型

short 是 Java 原始類型。short 變量可以存儲 16 位帶符號的整數(shù)。

Short 類是 short 原始類型的包裝對象類。它定義代表此類型的值的范圍的 MIN_VALUE 和 MAX_VALUE 常量。

Java 中的所有整數(shù)值都是 32 位的 int 值,除非值后面有 l 或 L(如 235L),這表示該值應(yīng)解釋為 long。

9) null 空

null 是 Java 的保留字,表示無值。

將 null 賦給非原始變量相當(dāng)于釋放該變量先前所引用的對象。

不能將 null 賦給原始類型(byte、short、int、long、char、float、double、boolean)變量。

10) true 真

true 關(guān)鍵字表示 boolean 變量的兩個合法值中的一個。

11) false 假

false 關(guān)鍵字代表 boolean 變量的兩個合法值之一。

7、變量引用

1) super 父類,超類

super 關(guān)鍵字用于引用使用該關(guān)鍵字的類的超類。

作為獨(dú)立語句出現(xiàn)的 super 表示調(diào)用超類的構(gòu)造方法。 super.() 表示調(diào)用超類的方法。只有在如下情況中才需要采用這種用法:要調(diào)用在該類中被重寫的方法,以便指定應(yīng)當(dāng)調(diào)用在超類中的該方法。

2) this 本類

this 關(guān)鍵字用于引用當(dāng)前實(shí)例。 當(dāng)引用可能不明確時,可以使用 this 關(guān)鍵字來引用當(dāng)前的實(shí)例。

3) void 無返回值

void 關(guān)鍵字表示 null 類型。 void 可以用作方法的返回類型,以指示該方法不返回值。

8、保留字

正確識別java語言的關(guān)鍵字(keyword)和保留字(reserved word)是十分重要的。Java的關(guān)鍵字對java的編譯器有特殊的意義,他們用來表示一種數(shù)據(jù)類型,或者表示程序的結(jié)構(gòu)等。保留字是為java預(yù)留的關(guān)鍵字,他們雖然現(xiàn)在沒有作為關(guān)鍵字,但在以后的升級版本中有可能作為關(guān)鍵字。 識別java語言的關(guān)鍵字,不要和其他語言如c/c++的關(guān)鍵字混淆。 const和goto是java的保留字。 所有的關(guān)鍵字都是小寫

1) goto 跳轉(zhuǎn)

goto 保留關(guān)鍵字,但無任何作用。結(jié)構(gòu)化程序設(shè)計完全不需要 goto 語句即可完成各種流程,而 goto 語句的使用往往會使程序的可讀性降低,所以 Java 不允許 goto 跳轉(zhuǎn)。

2) const 靜態(tài)

const 保留字,是一個類型修飾符,使用const聲明的對象不能更新。與final某些類似。

感謝各位的閱讀,以上就是“Java關(guān)鍵字和保留字是什么”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對Java關(guān)鍵字和保留字是什么這一問題有了更深刻的體會,具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司,,小編將為大家推送更多相關(guān)知識點(diǎn)的文章,歡迎關(guān)注!


網(wǎng)站題目:Java關(guān)鍵字和保留字是什么-創(chuàng)新互聯(lián)
文章網(wǎng)址:http://weahome.cn/article/gedpj.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部