java默認修飾符
Ⅰ java類中的成員預設(默認的)的修飾符是什麼
java類中成員預設的修飾符是不寫修飾符,理解為friendly(default),擁有的許可權是包許可權。
成員變版量或成員方法聲明為權默認許可權,則其是包級可見,同一個包內的類可以訪問到這個屬性或方法。若是類聲明為默認許可權,則同一個包下的類都可以訪問到該類,並可以實例化該類(當然如果這個類不具有實例化的能力除外,比如該類沒有提供public的構造函數)
Java許可權有四個,分別為public,protected,默認,private,其開放程度依次降低
public可供所有類訪問
protected繼承可見
private只能類本身內部的方法可以訪問
Ⅱ java中默認的修飾符到底是friendly,還是default
其實他們的概念都一樣,但java中沒有friendly的說法,那是c中的。think in java (java編程思想)中在說四大訪問修飾符時,提到了friendly是默認修飾符(估計就是因為這個很多人搞不清楚friendly和defoult)
Ⅲ java 類 修飾符 默認 是什麼類型
java中 默認是default 但是方法中不能寫, 也就是說沒有修飾符的方法就是 默認方法 default方法
Ⅳ Java的類,方法,變數等等的默認修飾符是什麼
訪問控制修飾符
Java中,可以使用訪問控制符來保護對類、變數、方法和構造方法的訪問。Java支持4種不同的訪問許可權。
默認的,也稱為default,在同一包內可見,不使用任何修飾符。
私有的,以private修飾符指定,在同一類內可見。
共有的,以public修飾符指定,對所有類可見。
受保護的,以protected修飾符指定,對同一包內的類和所有子類可見。
默認訪問修飾符-不使用任何關鍵字
使用默認訪問修飾符聲明的變數和方法,對同一個包內的類是可見的。介面里的變數都隱式聲明為public static final,而介面里的方法默認情況下訪問許可權為public。
實例:
如下例所示,變數和方法的聲明可以不使用任何修飾符。
String version = "1.5.1";
boolean processOrder() {
return true;
}
私有訪問修飾符-private
私有訪問修飾符是最嚴格的訪問級別,所以被聲明為private的方法、變數和構造方法只能被所屬類訪問,並且類和介面不能聲明為private。
聲明為私有訪問類型的變數只能通過類中公共的getter方法被外部類訪問。
Private訪問修飾符的使用主要用來隱藏類的實現細節和保護類的數據。
下面的類使用了私有訪問修飾符:
public class Logger {
private String format;
public String getFormat() {
return this.format;
}
public void setFormat(String format) {
this.format = format;
}
}
實例中,Logger類中的format變數為私有變數,所以其他類不能直接得到和設置該變數的值。為了使其他類能夠操作該變數,定義了兩個public方法:getFormat() (返回format的值)和setFormat(String)(設置format的值)
公有訪問修飾符-public
被聲明為public的類、方法、構造方法和介面能夠被任何其他類訪問。
如果幾個相互訪問的public類分布在不用的包中,則需要導入相應public類所在的包。由於類的繼承性,類所有的公有方法和變數都能被其子類繼承。
以下函數使用了公有訪問控制:
public static void main(String[] arguments) {
// ...
}
Java程序的main() 方法必須設置成公有的,否則,Java解釋器將不能運行該類。
受保護的訪問修飾符-protected
被聲明為protected的變數、方法和構造器能被同一個包中的任何其他類訪問,也能夠被不同包中的子類訪問。
Protected訪問修飾符不能修飾類和介面,方法和成員變數能夠聲明為protected,但是介面的成員變數和成員方法不能聲明為protected。
子類能訪問Protected修飾符聲明的方法和變數,這樣就能保護不相關的類使用這些方法和變數。
下面的父類使用了protected訪問修飾符,子類重載了父類的openSpeaker()方法。
class AudioPlayer {
protected boolean openSpeaker(Speaker sp) {
// 實現細節
}
}
class StreamingAudioPlayer {
boolean openSpeaker(Speaker sp) {
// 實現細節
}
}
如果把openSpeaker()方法聲明為private,那麼除了AudioPlayer之外的類將不能訪問該方法。如果把openSpeaker()聲明為public,那麼所有的類都能夠訪問該方法。如果我們只想讓該方法對其所在類的子類可見,則將該方法聲明為protected。
訪問控制和繼承
請注意以下方法繼承的規則:
父類中聲明為public的方法在子類中也必須為public。
父類中聲明為protected的方法在子類中要麼聲明為protected,要麼聲明為public。不能聲明為private。
父類中默認修飾符聲明的方法,能夠在子類中聲明為private。
父類中聲明為private的方法,不能夠被繼承。
非訪問修飾符
為了實現一些其他的功能,Java也提供了許多非訪問修飾符。
static修飾符,用來創建類方法和類變數。
Final修飾符,用來修飾類、方法和變數,final修飾的類不能夠被繼承,修飾的方法不能被繼承類重新定義,修飾的變數為常量,是不可修改的。
Abstract修飾符,用來創建抽象類和抽象方法。
Synchronized和volatile修飾符,主要用於線程的編程。
Static修飾符
靜態變數:
Static關鍵字用來聲明獨立於對象的靜態變數,無論一個類實例化多少對象,它的靜態變數只有一份拷貝。 靜態變數也被成為類變數。局部變數能被聲明為static變數。
靜態方法:
Static關鍵字用來聲明獨立於對象的靜態方法。靜態方法不能使用類的非靜態變數。靜態方法從參數列表得到數據,然後計算這些數據。
對類變數和方法的訪問可以直接使用classname.variablename和classname.methodname的方式訪問。
如下例所示,static修飾符用來創建類方法和類變數。
public class InstanceCounter {
private static int numInstances = 0;
protected static int getCount() {
return numInstances;
}
private static void addInstance() {
numInstances++;
}
InstanceCounter() {
InstanceCounter.addInstance();
}
public static void main(String[] arguments) {
System.out.println("Starting with " +
InstanceCounter.getCount() + " instances");
for (int i = 0; i < 500; ++i){
new InstanceCounter();
}
System.out.println("Created " +
InstanceCounter.getCount() + " instances");
}
}
以上實例運行編輯結果如下:
Started with 0 instances
Created 500 instances
Final修飾符
Final變數:
Final變數能被顯式地初始化並且只能初始化一次。被聲明為final的對象的引用不能指向不同的對象。但是final對象里的數據可以被改變。也就是說final對象的引用不能改變,但是裡面的值可以改變。
Final修飾符通常和static修飾符一起使用來創建類常量。
實例:
public class Test{
final int value = 10;
// 下面是聲明常量的實例
public static final int BOXWIDTH = 6;
static final String TITLE = "Manager";
public void changeValue(){
value = 12; //將輸出一個錯誤
}
}
Final方法
類中的Final方法可以被子類繼承,但是不能被子類修改。
聲明final方法的主要目的是防止該方法的內容被修改。
如下所示,使用final修飾符聲明方法。
public class Test{
public final void changeName(){
// 方法體
}
}
Final類
Final類不能被繼承,沒有類能夠繼承final類的任何特性。
實例:
public final class Test {
// 類體
}
Abstract修飾符
抽象類:
抽象類不能用來實例化對象,聲明抽象類的唯一目的是為了將來對該類進行擴充。
一個類不能同時被abstract和final修飾。如果一個類包含抽象方法,那麼該類一定要聲明為抽象類,否則將出現編譯錯誤。
抽象類可以包含抽象方法和非抽象方法。
實例:
abstract class Caravan{
private double price;
private String model;
private String year;
public abstract void goFast(); //抽象方法
public abstract void changeColor();
}
抽象方法
抽象方法是一種沒有任何實現的方法,該方法的的具體實現由子類提供。抽象方法不能被聲明成final和strict。
任何繼承抽象類的子類必須實現父類的所有抽象方法,除非該子類也是抽象類。
如果一個類包含若干個抽象方法,那麼該類必須聲明為抽象類。抽象類可以不包含抽象方法。
抽象方法的聲明以分號結尾,例如:public abstract sample();
實例:
public abstract class SuperClass{
abstract void m(); //抽象方法
}
class SubClass extends SuperClass{
//實現抽象方法
void m(){
.........
}
}
Synchronized修飾符
Synchronized關鍵字聲明的方法同一時間只能被一個線程訪問。Synchronized修飾符可以應用於四個訪問修飾符。
實例:
public synchronized void showDetails(){
.......
}
Transient修飾符
序列化的對象包含被transient修飾的實例變數時,java虛擬機(JVM)跳過該特定的變數。
該修飾符包含在定義變數的語句中,用來預處理類和變數的數據類型。
實例:
public transient int limit = 55; // will not persist
public int b; // will persist
volatile修飾符
Volatile修飾的成員變數在每次被線程訪問時,都強迫從共享內存中重讀該成員變數的值。而且,當成員變數發生變化時,強迫線程將變化值回寫到共享內存。這樣在任何時刻,兩個不同的線程總是看到某個成員變數的同一個值。一個volatile對象引用可能是null。
實例:
public class MyRunnable implements Runnable
{
private volatile boolean active;
public void run()
{
active = true;
while (active) // line 1
{
// 代碼
}
}
public void stop()
{
active = false; // line 2
}
}
一般地,在一個線程中調用run()方法,在另一個線程中調用stop()方法。如果line 1中的active位於緩沖區的值被使用,那麼當把line 2中的active設置成false時,循環也不會停止。
Ⅳ Java中成員屬性默認訪問修飾符是什麼
默認是default,意思是只能跟這個類在同一個包中的類來訪問,比私有private限制少,比protectd要限制多
Ⅵ java訪問修飾符public,private,protected,以及不寫(默認)時的區別
修飾符 當前類 同包 子類 其他包
public √ √ √ √
protected √ √ √ ×
default √ √ × ×
private √ × × ×
類的成員不寫訪問修飾時默認為default。默認對於同一個包中的其他類相當於公開(public),對於不是同一個包中的其他類相當於私有(private)。受保護(protected)對子類相當於公開,對不是同一包中的沒有父子關系的類相當於私有。Java中,外部類的修飾符只能是public或默認,類的成員(包括內部類)的修飾符可以是以上四種。
Ⅶ java中類的默認訪問修飾符的問題,問題如下:
如果都不是內部類,肯定是矛盾的
首先沒用public修飾時,類名和文件名可以不一致,故定義兩個不同名文件,卻定義了兩個同名類並不奇怪
其次你沒有提示問題的最大可能是你的編譯器不夠智能,沒有檢測到該矛盾,使用eclipse等工具正常情況下是會檢測出來的
再次,你可以這樣理解,每個類都需要編譯成class文件才能執行,按照上面的方式定義,兩個class文件應該被編譯到同一個位置,從操作系統的角度看,同樣是矛盾的.
Ⅷ java中默認修飾符問題
你在也是在同一個包及同一個類下的啊 。