Heim >Java >javaLernprogramm >Detaillierte Erläuterung der Java-Modifikatoren

Detaillierte Erläuterung der Java-Modifikatoren

高洛峰
高洛峰Original
2017-01-24 15:27:161281Durchsuche

Die Java-Sprache bietet viele Modifikatoren, die hauptsächlich in die folgenden zwei Kategorien unterteilt sind:

Zugriffsmodifikatoren

Nichtzugriffsmodifikatoren

Modifikatoren werden zum Definieren von Klassen verwendet , Methoden oder Variablen werden normalerweise am Anfang der Anweisung platziert. Zur Veranschaulichung verwenden wir das folgende Beispiel:

public class className {
  // ...
}
private boolean myFlag;
static final double weeks = 9.5;
protected static final int BOXWIDTH = 42;
public static void main(String[] arguments) {
  // 方法体
}

Zugriffskontrollmodifikator

In Java können Zugriffskontrollmodifikatoren verwendet werden, um den Zugriff auf Klassen, Variablen, Methoden und Konstruktoren zu schützen. Java unterstützt 4 verschiedene Zugriffsrechte.

Der Standardwert, auch Standardwert genannt, ist innerhalb desselben Pakets sichtbar und verwendet keine Modifikatoren.

Privat, angegeben mit dem Modifikator „private“, sichtbar innerhalb derselben Klasse.

Geteilt, mit dem öffentlichen Modifikator angegeben, für alle Klassen sichtbar.

Geschützt, angegeben mit dem geschützten Modifikator, sichtbar für Klassen und alle Unterklassen im selben Paket.

Standardzugriffsmodifikator – keine Schlüsselwörter verwenden

Variablen und Methoden, die mit dem Standardzugriffsmodifikator deklariert werden, sind für Klassen im selben Paket sichtbar. Die Variablen in der Schnittstelle werden implizit als öffentliches statisches Finale deklariert, und die Zugriffsrechte der Methoden in der Schnittstelle sind standardmäßig öffentlich.

Beispiel:

Wie im folgenden Beispiel gezeigt, können Variablen und Methoden ohne Modifikatoren deklariert werden.

String version = "1.5.1";
boolean processOrder() {
  return true;
}

Privater Zugriffsmodifikator-private

Privater Zugriffsmodifikator ist die strengste Zugriffsebene, sodass als privat deklarierte Methoden, Variablen und Konstruktoren nur von der Klasse aufgerufen werden können, zu der sie gehören. , und Klassen und Schnittstellen können nicht als privat deklariert werden.

Variablen, die als private Zugriffstypen deklariert sind, können nur von externen Klassen über die öffentlichen Getter-Methoden in der Klasse aufgerufen werden.

Die Verwendung des privaten Zugriffsmodifikators wird hauptsächlich dazu verwendet, die Implementierungsdetails der Klasse auszublenden und die Daten der Klasse zu schützen.

Die folgenden Klassen verwenden den privaten Zugriffsmodifikator:

public class Logger {
  private String format;
  public String getFormat() {
   return this.format;
  }
  public void setFormat(String format) {
   this.format = format;
  }
}

In der Instanz ist die Formatvariable in der Logger-Klasse eine private Variable, sodass andere Klassen den Wert nicht direkt abrufen und festlegen können der Variablen. Damit andere Klassen diese Variable bedienen können, werden zwei öffentliche Methoden definiert: getFormat() (gibt den Wert von format zurück) und setFormat(String) (legt den Wert von format fest)

Public access modifier-public

Auf Klassen, Methoden, Konstruktoren und Schnittstellen, die als öffentlich deklariert sind, kann jede andere Klasse zugreifen.

Wenn mehrere öffentliche Klassen, die aufeinander zugreifen, in verschiedenen Paketen verteilt sind, müssen Sie das Paket dort importieren, wo sich die entsprechende öffentliche Klasse befindet. Aufgrund der Klassenvererbung können alle öffentlichen Methoden und Variablen einer Klasse von ihren Unterklassen geerbt werden.

Die folgenden Funktionen verwenden die öffentliche Zugriffskontrolle:

public static void main(String[] arguments) {
  // ...
}

Die Methode main() des Java-Programms muss auf öffentlich gesetzt sein, andernfalls wird dies der Java-Interpreter tun Diese Klasse kann nicht ausgeführt werden.

Geschützter Zugriff durch Modifikatoren geschützt

Variablen, Methoden und Konstruktoren, die als geschützt deklariert sind, können von jeder anderen Klasse im selben Paket oder von Klassen in verschiedenen Paketen mit Unterklassenzugriff aufgerufen werden.

Geschützter Zugriffsmodifikator kann keine Klassen und Schnittstellen ändern, aber Mitgliedsvariablen und Mitgliedsmethoden von Schnittstellen können nicht als geschützt deklariert werden.

Unterklassen können auf die durch den Protected-Modifikator deklarierten Methoden und Variablen zugreifen und so nicht verwandte Klassen vor der Verwendung dieser Methoden und Variablen schützen.

Die folgende übergeordnete Klasse verwendet den geschützten Zugriffsmodifikator und die Unterklasse überlädt die openSpeaker()-Methode der übergeordneten Klasse.

class AudioPlayer {
  protected boolean openSpeaker(Speaker sp) {
   // 实现细节
  }
}
class StreamingAudioPlayer {
  boolean openSpeaker(Speaker sp) {
   // 实现细节
  }
}

Wenn die openSpeaker()-Methode als privat deklariert ist, können andere Klassen als AudioPlayer nicht auf diese Methode zugreifen. Wenn openSpeaker() als öffentlich deklariert ist, können alle Klassen auf diese Methode zugreifen. Wenn wir möchten, dass die Methode nur für Unterklassen ihrer Klasse sichtbar ist, deklarieren Sie die Methode als geschützt.

Zugriffskontrolle und Vererbung

Bitte beachten Sie die folgenden Regeln für die Methodenvererbung:

Methoden, die in der übergeordneten Klasse als öffentlich deklariert wurden, müssen auch in der untergeordneten Klasse öffentlich sein.

Methoden, die in der übergeordneten Klasse als geschützt deklariert wurden, werden in der Unterklasse entweder als geschützt oder öffentlich deklariert. Kann nicht als privat deklariert werden.

Methoden, die in der übergeordneten Klasse als privat deklariert wurden, können nicht vererbt werden.

Nichtzugriffsmodifikatoren

Um einige andere Funktionen zu implementieren, stellt Java auch viele Nichtzugriffsmodifikatoren bereit.

statischer Modifikator, der zum Erstellen von Klassenmethoden und Klassenvariablen verwendet wird.

Der Final-Modifikator wird zum Ändern von Klassen, Methoden und Variablen verwendet. Durch Final geänderte Klassen können nicht vererbt werden, geänderte Methoden können nicht durch geerbte Klassen neu definiert werden und geänderte Variablen sind Konstanten und können nicht geändert werden.

Abstrakter Modifikator, der zum Erstellen abstrakter Klassen und abstrakter Methoden verwendet wird.

Synchronisierte und flüchtige Modifikatoren werden hauptsächlich für die Thread-Programmierung verwendet.

Statischer Modifikator

Statische Variablen:

Das Schlüsselwort „Static“ wird verwendet, um statische Variablen unabhängig von Objekten zu deklarieren. Unabhängig davon, wie viele Objekte eine Klasse instanziiert, sind ihre statischen Variablen nur A Kopie. Statische Variablen werden auch Klassenvariablen genannt. Lokale Variablen können als statische Variablen deklariert werden.

Statische Methode:

Das Schlüsselwort „Static“ wird verwendet, um statische Methoden unabhängig vom Objekt zu deklarieren. Statische Methoden können keine nicht statischen Variablen der Klasse verwenden. Statische Methoden rufen Daten aus einer Parameterliste ab und berechnen die Daten dann.

Der Zugriff auf Klassenvariablen und -methoden kann direkt über classname.variablename und classname.methodname erfolgen.

Wie im folgenden Beispiel gezeigt, wird der statische Modifikator zum Erstellen von Klassenmethoden und Klassenvariablen verwendet.

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");
  }
}


Die obigen Ausführungs- und Bearbeitungsergebnisse der Instanz lauten wie folgt:

Mit 0 Instanzen gestartet
500 Instanzen erstellt

Letzter Modifikator

Letzte Variable:

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时,循环也不会停止。

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持PHP中文网!

更多详解Java修饰符相关文章请关注PHP中文网!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn