Java 修飾符。本站提示廣大學習愛好者:(Java 修飾符)文章只能為提供參考,不一定能成為您想要的結果。以下是Java 修飾符正文
Java言語提供了很多修飾符,次要分為以下兩類:
修飾符用來定義類、辦法或許變量,通常放在語句的最前端。我們經過上面的例子來闡明:
public class className { // ... } private boolean myFlag; static final double weeks = 9.5; protected static final int BOXWIDTH = 42; public static void main(String[] arguments) { // 辦法體 }
Java中,可以運用訪問控制符來維護對類、變量、辦法和結構辦法的訪問。Java支持4種不同的訪問權限。
默許的,也稱為default,在同一包內可見,不運用任何修飾符。
公有的,以private修飾符指定,在同一類內可見。
共有的,以public修飾符指定,對一切類可見。
受維護的,以protected修飾符指定,對同一包內的類和一切子類可見。
運用默許訪問修飾符聲明的變量和辦法,對同一個包內的類是可見的。接口裡的變量都隱式聲明為public static final,而接口裡的辦法默許狀況下訪問權限為public。
實例:
如下例所示,變量和辦法的聲明可以不運用任何修飾符。
String version = "1.5.1"; boolean processOrder() { return true; }
公有訪問修飾符是最嚴厲的訪問級別,所以被聲明為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 static void main(String[] arguments) { // ... }
Java順序的main() 辦法必需設置成私有的,否則,Java解釋器將不能運轉該類。
被聲明為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的辦法,不可以被承繼。
為了完成一些其他的功用,Java也提供了許多非訪問修飾符。
static修飾符,用來創立類辦法和類變量。
Final修飾符,用來修飾類、辦法和變量,final修飾的類不可以被承繼,修飾的辦法不能被承繼類重新定義,修飾的變量為常量,是不可修正的。
Abstract修飾符,用來創立籠統類和籠統辦法。
Synchronized和volatile修飾符,次要用於線程的編程。
靜態變量:
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修飾符通常和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修飾符聲明辦法。
public class Test{ public final void changeName(){ // 辦法體 } }
Final類不能被承繼,沒有類可以承繼final類的任何特性。
實例:
public final class Test { // 類體 }
籠統類:
籠統類不能用來實例化對象,聲明籠統類的獨一目的是為了未來對該類停止擴大。
一個類不能同時被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修飾符可以使用於四個訪問修飾符。
實例:
public synchronized void showDetails(){ ....... }
序列化的對象包括被transient修飾的實例變量時,java虛擬機(JVM)跳過該特定的變量。
該修飾符包括在定義變量的語句中,用來預處置類和變量的數據類型。
實例:
public transient int limit = 55; // will not persist public int b; // will persist
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時,循環也不會中止。