當前位置:首頁 » 密碼管理 » java內部類訪問許可權

java內部類訪問許可權

發布時間: 2024-11-25 14:05:59

『壹』 java內部類的問題

什麼是內部類

在一個類內部的類,我們稱之為內部類。

內部類可以很好地實現隱藏,一般的非內部類是不允許有 private 與 protected 許可權的,但內部類可以。內部類擁有外圍類的所有元素的訪問許可權。

內部類分類:

內部類可以分為:實例內部類、靜態內部類和成員內部類,每種內部類都有它特定的一些特點。

在類 A 中定義類 B,那麼類 B 就是內部類,也稱為嵌套類,相對而言,類 A 就是外部類。如果有多層嵌套,例如類 A 中有內部類 B,而類 B 中還有內部類 C,那麼通常將最外層的類稱為頂層類(或者頂級類)。

『貳』 Java 訪問修飾符詳解

Java 訪問修飾符詳解


Java中類和其成員的訪問許可權通過四種修飾符實現:public、protected、default(即不寫)和private。類訪問許可權的重要性在於確定其與其他類的關系和可見性。


首先,對於普通類,訪問修飾符不能是private,因為這將使其在其他類中不可見,無法使用,也無法被繼承,這與類的初衷相悖。同樣,protected被限制,因為Java缺乏子包概念,如果允許protected,會導致訪問邏輯上的死鎖,因此普通類通常僅限於包內訪問和包外訪問,public和default就足夠了。


內部類則不同,它們可以使用所有四種修飾符,因為它們與外部類存在明確的繼承關系,這使得它們的訪問許可權可以根據需要進行更為精細的控制。內部類的訪問修飾符靈活性更高。


成員變數和方法的訪問修飾符也類似,但有兩點值得注意:private限制了訪問,類的構造方法若為private,將無法直接實例化,通常用於實現單例模式;而protected則強調方法的「保護」性,有助於封裝和體系的穩定性,如Spring框架中的抽象類中使用protected方法來維護繼承體系的結構。

『叄』 Java中private,protected,public和default的區別

private,public,protected,默認不寫(firendly)

1、Class類的訪問許可權:

public:可以供所有的類訪問。

默認:默認可以稱為friendly但是,Java語言中是沒有friendly這個修飾符的,這樣稱呼應該是來源於c++。默認的訪問許可權是包級訪問許可權。

即如果寫了一個類沒有寫訪問許可權修飾符,那麼就是默認的訪問許可權,同一個包下的類都可以訪問到,即使可以實例化該類

(當然如果這個類不具有實例化的能力除外,比如該類沒有提供public的構造函數)。

說明:

1、每個編譯單元(類文件)都僅能有一個publicclass

2、publicclass的名稱(包含大小寫)必須和其類文件同名。

3、一個類文件(*.java)中可以不存在publicclass。

這種形式的存在的場景:如果我們在某個包內撰寫一個class,僅僅是為了配合同包內的其他類工作,而且

我們不想再為了撰寫說明文檔給客戶(不一定是現實意義的客戶,可能是調用這個類的類)看而傷腦筋,而且有可能過一段時間之後

有可能會徹底改變原有的做法,並完全舍棄舊版本,以全新的版本代替。

4、class不可以是private和protected。

5、如果不希望那個任何產生某個class的對象,可以將該類得所有構造函數設置成private。但是即使這樣也可以生成該類的對象,就是class的static的成員(屬性和方法)可以辦到。

2、類成員變數的訪問許可權:

public:緊接public的屬性任何類都可以訪問到。可以直接使用ClassName.propertyName。但是從類的封裝性上來考慮將一個類的屬性定義成public一般很少使用,

在定義靜態常量的時候通暢會這樣定義。如:publicstaticfinalintPAGE_SIZE=10;

private:只有類本身內部的方法可以訪問類的private屬性,當然內部類也可以訪問其外部類的private成員的。(屬性和方法)

默認(friendly):包級可見,同一個包內的類可以訪問到這個屬性,可以直接使用className.propertyName來訪問,但是從類的封裝性特性來說很少這樣使用類的屬性的。

protected:關鍵字所處理的是所謂「繼承」的觀念。對於同一包的其他類,protected=默認,對於不同包的類,如果存在繼承關系,而baseClass存在protected屬性,則可以被其自繼承,而不同包的其他類

則不能訪問類的protected屬性。

3、類的成員方法的訪問許可權:

其從語法角度來講,這些訪問許可權控制符作用於類的方法和作用於類的屬性上的效果是一樣的。

public:所有類可見。

pirvate:只有同一類內部的方法可見,在有就是內部類也可以訪問到。

默認(friendly):包內可見。

protected:繼承可見。

4、訪問許可權存在的理由

1、「讓使用者無法碰觸到他們不該碰觸的東西。」這些東西僅供類的內部機制使用。將某些成員聲明成private,對於使用者來說可以說是一種服務,

因為這樣使用者可以知道哪些是他關注的哪些是不重要的,不需要關注,如此歷來對於使用來說降低了對使用對象認識的難度。

2、(最終要的理由)讓程序設計者可以更動class內部運作方式,而無須擔心波及到客戶端程序。

java的「訪問許可權修飾符」賦予classes開發者極具有價值的控制能力。身為classes開發者,如果你的任何改變可以完全不幹擾你的使用者,

你便可以安心改變你的底層實現,因為客戶端程序員無法訪問class的這一部分。

『肆』 Java中的四種訪問控制域是什麼

private,public,protected,默認不寫(firendly)

1、Class類的訪問許可權:
public:可以供所有的類訪問。
默認:默認可以稱為friendly但是,java語言中是沒有friendly這個修飾符的,這樣稱呼應該是來源於c++。默認的訪問許可權是包級訪問許可權。
即如果寫了一個類沒有寫訪問許可權修飾符,那麼就是默認的訪問許可權,同一個包下的類都可以訪問到,即使可以實例化該類
(當然如果這個類不具有實例化的能力除外,比如該類沒有提供public的構造函數)。

說明:
1、每個編譯單元(類文件)都僅能有一個public class
2、public class的名稱(包含大小寫)必須和其類文件同名。
3、一個類文件(*.java)中可以不存在public class。
這種形式的存在的場景:如果我們在某個包內撰寫一個class,僅僅是為了配合同包內的其他類工作,而且
我們不想再為了撰寫說明文檔給客戶(不一定是現實意義的客戶,可能是調用這個類的類)看而傷腦筋,而且有可能過一段時間之後
有可能會徹底改變原有的做法,並完全舍棄舊版本,以全新的版本代替。
4、class不可以是private和protected。
5、如果不希望那個任何產生某個class的對象,可以將該類得所有構造函數設置成private。但是即使這樣也可以生成該類的對象,就是class的static的成員(屬性和方法)可以辦到。

2、類成員變數的訪問許可權:
public:緊接public的屬性任何類都可以訪問到。可以直接使用ClassName.propertyName。但是從類的封裝性上來考慮將一個類的屬性定義成public一般很少使用,
在定義靜態常量的時候通暢會這樣定義。如:public static final int PAGE_SIZE=10;
private:只有類本身內部的方法可以訪問類的private屬性,當然內部類也可以訪問其外部類的private成員的。(屬性和方法)
默認(friendly):包級可見,同一個包內的類可以訪問到這個屬性,可以直接使用className.propertyName來訪問,但是從類的封裝性特性來說很少這樣使用類的屬性的。
protected:關鍵字所處理的是所謂「繼承」的觀念。對於同一包的其他類,protected=默認,對於不同包的類,如果存在繼承關系,而baseClass存在protected屬性,則可以被其自繼承,而不同包的其他類
則不能訪問類的protected屬性。

3、類的成員方法的訪問許可權:
其從語法角度來講,這些訪問許可權控制符作用於類的方法和作用於類的屬性上的效果是一樣的。
public:所有類可見。
pirvate:只有同一類內部的方法可見,在有就是內部類也可以訪問到。
默認(friendly):包內可見。
protected:繼承可見。

4、訪問許可權存在的理由
1、「讓使用者無法碰觸到他們不該碰觸的東西。」這些東西僅供類的內部機制使用。將某些成員聲明成private,對於使用者來說可以說是一種服務,
因為這樣使用者可以知道哪些是他關注的哪些是不重要的,不需要關注,如此歷來對於使用來說降低了對使用對象認識的難度。
2、(最終要的理由)讓程序設計者可以更動class內部運作方式,而無須擔心波及到客戶端程序。

5、java的「訪問許可權修飾符」賦予classes開發者極具有價值的控制能力。身為classes開發者,如果你的任何改變可以完全不幹擾你的使用者,
你便可以安心改變你的底層實現,因為客戶端程序員無法訪問class的這一部分。
通過今天學習訪問許可權的問題了解到,介面或者抽象等等策略所謂的「實現隱藏」其根本原因並不是說為了隱藏實現的代碼和思路,而是降低使用者的使用難度,以及從維護角度來說可見范圍的控制給程序維護帶來了極大的安全性。

『伍』 java中的四種訪問許可權是

1、私有許可權(private)

private可以修飾數據成員,構造方法,方法成員,不能修飾類(此處指外部類,不考慮內部類)。被private修飾的成員,只能在定義它們的類中使用,在其他類中不能調用。

2、默認許可權(default)

類,數據成員,構造方法,方法成員,都能夠使用默認許可權,即不寫任何關鍵字。默認許可權即同包許可權,同包許可權的元素只能在定義它們的類中,以及同包的類中被調用。

3、受保護許可權(protected)

protected可以修飾數據成員,構造方法,方法成員,不能修飾類(此處指外部類,不考慮內部類)。被protected修飾的成員,能在定義它們的類中,同包的類中被調用。如果有不同包的類想調用它們,那麼這個類必須是定義它們的類的子類。

4、公共許可權(public)

public可以修飾類,數據成員,構造方法,方法成員。被public修飾的成員,可以在任何一個類中被調用,不管同包或不同包,是許可權最大的一個修飾符。

『陸』 java 內部類和外部類的區別

1. Java項目一般從src目錄開始有com...A.java這樣的目錄結構。這就是包結構。所以一般編譯後的結構是跟包結構一模一樣的,這樣的結構保證了import時能找到正確的class引用包訪問許可權就是指同包下的類可見。
import 一般加上全路徑,並且使用.*時只包含當前目錄的所有類文件,不包括子目錄。
2. 外部明遲類只有public和default兩種修飾,要麼全局可訪問,要麼包內可訪問。
3. 內部類可以有全部訪問許可權,因亂數為它的概念就是一個成員變數,所以訪問許可權設置與一般的成員變數相同嘩槐首。
非靜態內部類是外部類的一個成員變數,只跟外部類的實例有關。
靜態內部類是獨立於外部類存在的一個類,與外部類實例無關,可以通過外部類.內部類直接獲取Class類型。
想要了解更多可以跟我一起討論哦

熱點內容
如何給監控加訪問密碼 發布:2024-11-25 16:45:13 瀏覽:600
國外安卓音樂播放器哪個好 發布:2024-11-25 16:35:58 瀏覽:142
我的世界伺服器增加粒子 發布:2024-11-25 16:28:29 瀏覽:717
帶內核的安卓x86是什麼意思 發布:2024-11-25 16:27:01 瀏覽:272
php了解 發布:2024-11-25 16:16:26 瀏覽:933
個人搭建伺服器要錢不 發布:2024-11-25 16:06:56 瀏覽:832
伺服器磁碟滿了怎麼辦 發布:2024-11-25 16:06:14 瀏覽:19
python代碼文本分類 發布:2024-11-25 16:05:22 瀏覽:224
加密cf備份 發布:2024-11-25 16:05:21 瀏覽:442
java加鎖 發布:2024-11-25 15:50:26 瀏覽:397