Maison > Java > javaDidacticiel > Explication détaillée des modificateurs Java

Explication détaillée des modificateurs Java

高洛峰
Libérer: 2017-01-24 15:27:16
original
1239 Les gens l'ont consulté

Le langage Java propose de nombreux modificateurs, qui sont principalement répartis dans les deux catégories suivantes :

Modificateurs d'accès

Modificateurs de non-accès

Les modificateurs sont utilisés pour définir des classes , Les méthodes ou variables sont généralement placées au début de l'instruction. Nous utilisons l'exemple suivant pour illustrer :

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

Modificateur de contrôle d'accès

En Java, les modificateurs de contrôle d'accès peuvent être utilisés pour protéger l'accès aux classes, variables, méthodes et constructeurs. Java prend en charge 4 droits d'accès différents.

La valeur par défaut, également appelée valeur par défaut, est visible dans le même package et n'utilise aucun modificateur.

Privé, spécifié avec le modificateur private, visible au sein de la même classe.

Partagé, spécifié avec le modificateur public, visible par toutes les classes.

Protégé, spécifié avec le modificateur protected, visible par les classes et toutes les sous-classes du même package.

Modificateur d'accès par défaut - n'utilisez aucun mot-clé

Les variables et méthodes déclarées à l'aide du modificateur d'accès par défaut sont visibles par les classes du même package. Les variables de l'interface sont implicitement déclarées comme public static final, et les droits d'accès des méthodes de l'interface sont publics par défaut.

Exemple :

Comme le montre l'exemple suivant, les variables et les méthodes peuvent être déclarées sans aucun modificateur.

String version = "1.5.1";
boolean processOrder() {
  return true;
}
Copier après la connexion

Modificateur d'accès privé-privé

Le modificateur d'accès privé est le niveau d'accès le plus strict, donc les méthodes, variables et constructeurs déclarés comme privés ne sont accessibles que par la classe à laquelle ils appartiennent. , et les classes et interfaces ne peuvent pas être déclarées privées.

Les variables déclarées comme types d'accès privés ne sont accessibles qu'aux classes externes via les méthodes getter publiques de la classe.

L'utilisation du modificateur d'accès privé est principalement utilisée pour masquer les détails d'implémentation de la classe et protéger les données de la classe.

Les classes suivantes utilisent le modificateur d'accès privé :

public class Logger {
  private String format;
  public String getFormat() {
   return this.format;
  }
  public void setFormat(String format) {
   this.format = format;
  }
}
Copier après la connexion

Dans l'exemple, la variable de format dans la classe Logger est une variable privée, donc les autres classes ne peuvent pas directement obtenir et définir la valeur de la variable. Afin de permettre à d'autres classes d'exploiter cette variable, deux méthodes publiques sont définies : getFormat() (renvoie la valeur du format) et setFormat(String) (définit la valeur du format)

Modificateur d'accès public-public

Les classes, méthodes, constructeurs et interfaces déclarés publics sont accessibles par n'importe quelle autre classe.

Si plusieurs classes publiques qui accèdent les unes aux autres sont distribuées dans des packages différents, vous devez importer le package où se trouve la classe publique correspondante. En raison de l'héritage de classe, toutes les méthodes et variables publiques d'une classe peuvent être héritées par ses sous-classes.

Les fonctions suivantes utilisent le contrôle d'accès public :

public static void main(String[] arguments) {
  // ...
}
Copier après la connexion

La méthode main() du programme Java doit être définie sur public, sinon l'interpréteur Java le fera ne pas pouvoir exécuter cette catégorie.

Accès protégé modifier-protected

Les variables, méthodes et constructeurs déclarés comme protégés sont accessibles par toute autre classe du même package, ou par les classes d'accès aux sous-classes de différents packages.

Le modificateur d'accès protégé ne peut pas modifier les classes et les interfaces. Les méthodes et les variables membres peuvent être déclarées comme protégées, mais les variables membres et les méthodes membres des interfaces ne peuvent pas être déclarées comme protégées.

Les sous-classes peuvent accéder aux méthodes et variables déclarées par le modificateur Protected, protégeant ainsi les classes non liées de l'utilisation de ces méthodes et variables.

La classe parent suivante utilise le modificateur d'accès protégé et la sous-classe surcharge la méthode openSpeaker() de la classe parent.

class AudioPlayer {
  protected boolean openSpeaker(Speaker sp) {
   // 实现细节
  }
}
class StreamingAudioPlayer {
  boolean openSpeaker(Speaker sp) {
   // 实现细节
  }
}
Copier après la connexion

Si la méthode openSpeaker() est déclarée privée, les classes autres qu'AudioPlayer ne pourront pas accéder à cette méthode. Si openSpeaker() est déclaré public, toutes les classes peuvent accéder à cette méthode. Si nous voulons que la méthode soit visible uniquement par les sous-classes de sa classe, déclarez la méthode comme protégée.

Contrôle d'accès et héritage

Veuillez noter les règles suivantes pour l'héritage des méthodes :

Les méthodes déclarées comme publiques dans la classe parent doivent également être publiques dans la classe enfant.

Les méthodes déclarées comme protégées dans la classe parent sont soit déclarées comme protégées, soit publiques dans la sous-classe. Ne peut pas être déclaré privé.

Les méthodes déclarées comme privées dans la classe parent ne peuvent pas être héritées.

Modificateurs de non-accès

Afin d'implémenter d'autres fonctions, Java fournit également de nombreux modificateurs de non-accès.

modificateur statique, utilisé pour créer des méthodes de classe et des variables de classe.

Le modificateur Final est utilisé pour modifier les classes, les méthodes et les variables. Les classes modifiées par final ne peuvent pas être héritées, les méthodes modifiées ne peuvent pas être redéfinies par les classes héritées et les variables modifiées sont des constantes et ne peuvent pas être modifiées.

Modificateur abstrait, utilisé pour créer des classes abstraites et des méthodes abstraites.

Les modificateurs synchronisés et volatils sont principalement utilisés pour la programmation des threads.

Modificateur statique

Variables statiques :

Le mot-clé statique est utilisé pour déclarer des variables statiques indépendantes des objets. Quel que soit le nombre d'objets qu'une classe instancie, ses variables statiques ne sont que des A. copie. Les variables statiques sont également appelées variables de classe. Les variables locales peuvent être déclarées comme variables statiques.

Méthode statique :

Le mot-clé Static est utilisé pour déclarer des méthodes statiques indépendantes de l'objet. Les méthodes statiques ne peuvent pas utiliser de variables non statiques de la classe. Les méthodes statiques récupèrent les données d'une liste de paramètres, puis calculent les données.

L'accès aux variables et méthodes de classe est directement accessible en utilisant classname.variablename et classname.methodname.

Comme le montre l'exemple suivant, le modificateur static est utilisé pour créer des méthodes de classe et des variables de classe.

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");
  }
}
Copier après la connexion


Les résultats d'exécution et de modification de l'instance ci-dessus sont les suivants :

Démarré avec 0 instance
Créé 500 instances

Modificateur final

Variable finale :

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; //将输出一个错误
 }
}
Copier après la connexion

Final方法

类中的Final方法可以被子类继承,但是不能被子类修改。

声明final方法的主要目的是防止该方法的内容被修改。

如下所示,使用final修饰符声明方法。

public class Test{
  public final void changeName(){
    // 方法体
  }
}
Copier après la connexion

Final类

Final类不能被继承,没有类能够继承final类的任何特性。

实例:

public final class Test {
  // 类体
}
Copier après la connexion

Abstract修饰符

抽象类:

抽象类不能用来实例化对象,声明抽象类的唯一目的是为了将来对该类进行扩充。

一个类不能同时被abstract和final修饰。如果一个类包含抽象方法,那么该类一定要声明为抽象类,否则将出现编译错误。

抽象类可以包含抽象方法和非抽象方法。

实例:

abstract class Caravan{
  private double price;
  private String model;
  private String year;
  public abstract void goFast(); //抽象方法
  public abstract void changeColor();
}
Copier après la connexion

抽象方法

抽象方法是一种没有任何实现的方法,该方法的的具体实现由子类提供。抽象方法不能被声明成final和strict。

任何继承抽象类的子类必须实现父类的所有抽象方法,除非该子类也是抽象类。

如果一个类包含若干个抽象方法,那么该类必须声明为抽象类。抽象类可以不包含抽象方法。

抽象方法的声明以分号结尾,例如:public abstract sample();

实例:

public abstract class SuperClass{
  abstract void m(); //抽象方法
}
class SubClass extends SuperClass{
   //实现抽象方法
   void m(){
     .........
   }
}
Copier après la connexion

Synchronized修饰符

Synchronized关键字声明的方法同一时间只能被一个线程访问。Synchronized修饰符可以应用于四个访问修饰符。

实例:

public synchronized void showDetails(){
.......
}
Copier après la connexion

Transient修饰符

序列化的对象包含被transient修饰的实例变量时,java虚拟机(JVM)跳过该特定的变量。

该修饰符包含在定义变量的语句中,用来预处理类和变量的数据类型。

实例:

public transient int limit = 55;  // will not persist
public int b; // will persist
Copier après la connexion

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
  }
}
Copier après la connexion

一般地,在一个线程中调用run()方法,在另一个线程中调用stop()方法。如果line 1中的active位于缓冲区的值被使用,那么当把line 2中的active设置成false时,循环也不会停止。

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

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

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal