Les modificateurs de non-accès sont les mots-clés introduits dans Java 7 pour informer la JVM du comportement, des méthodes ou des variables d'une classe, etc. Cela permet d'introduire des fonctionnalités supplémentaires, telles que le mot-clé final utilisé pour indiquer que la variable ne peut pas être initialisée deux fois. Il y a un total de 7 modificateurs de non-accès introduits.
Vous trouverez ci-dessous les types de modificateurs de non-accès en Java :
PUBLICITÉ Cours populaire dans cette catégorie MAÎTRISÉE JAVA - Spécialisation | 78 séries de cours | 15 tests simulésCe modificateur peut être appliqué avec :
Code :
final class Honda{ public void myFun1(){ System.out.println("Honda Class"); } } class Bike extends Honda{ public void myFun1(){ System.out.println("Bike Class"); } }
Sortie :
Code :
class Honda{ public final void myFun1(){ System.out.println("Honda Class"); } } class Bike extends Honda{ public void myFun1(){ System.out.println("Bike Class"); } }
Sortie :
Code :
public abstract class MyActivity{ public MyActivity(){ } public final String myFun1(){ } }
Exemple : public abstract void fun1();
Code :
abstract class Electronics { abstract void display(); abstract void display(String msg); } class Computers extends Electronics { @Override void display() { System.out.println("Abstract method is called"); } @Override void display(String txt) { System.out.println(txt); } } public class AbstractDemo { public static void main(String[] args) { Computers obj=new Computers(); obj.display(); obj.display("Method with arguments"); } }
Sortie :
Ce mot-clé permet d'empêcher l'accès d'une méthode par plusieurs threads simultanément, synchronisant ainsi le flux d'un programme et faisant ressortir les résultats souhaités à l'aide de la fonctionnalité multithreading.
Code :
class Person1 { public synchronized void sendFun(String txt) { System.out.println("Sending message\t" + txt ); try { Thread.sleep(1000); } catch (Exception e) { System.out.println("Thread interrupted."); } System.out.println("\n" + txt + "Sent"); } } class DemoThread extends Thread { private String txt; Person1 person; DemoThread(String m, Person1 obj) { txt = m; person = obj; } public void run() { synchronized(person) { person.sendFun(txt); } } } public class HelloWorld { public static void main(String args[]) { Person1 snd = new Person1(); DemoThread S1 = new DemoThread( " Hi " , snd ); DemoThread S2 = new DemoThread( " Bye " , snd ); S1.start(); S2.start(); // wait for threads to end try { S1.join(); S2.join(); } catch(Exception e) { System.out.println("Interrupted"); } } }
Sortie :
Cette variable est utilisée pour la gestion de la mémoire et est la première chose référencée lors du chargement d'une classe. Ces membres sont traités au niveau de la classe ; ainsi, ils ne peuvent pas être appelés à l’aide d’un objet ; au lieu de cela, le nom de la classe est utilisé pour y faire référence.
Code:
public class Demo { // static variable static int x = 10; static int y; //static class public static class DemoInnerClass{ static int z=10; } // static block static { System.out.println("Static block initialized."); y = x + 4; } //static method public static void main(String[] args) { System.out.println("from main"); System.out.println("Value of x : "+x); System.out.println("Value of y : "+y); System.out.println("Value of z : "+DemoInnerClass.z); } }
Output:
The native keyword is used only with the methods to indicate that the particular method is written in platform -dependent. These are used to improve the system’s performance, and the existing legacy code can be easily reused.
Note: Static, as well as abstract methods, cannot be declared as native.Example: Consider a function myfun1 in class NativeDemo that is written in C++. To use this code, we will create a link library mylib1 and load it using the class’s static block.
public class DateTimeUtils { public native String getSystemTime(); static { System.loadLibrary("nativedatetimeutils"); } }
Code:
public class HelloWorld { public strictfp double calSum() { double n1 = 10e+07; double n2 = 9e+08; return (n1+n2); } public static strictfp void main(String[] args) { HelloWorld t = new HelloWorld (); System.out.println("Result is -" + t.calSum()); } }
Output:
While transferring the data from one end to another over a network, it must be serialised for successful receiving of data, which means convert to byte stream before sending and converting it back at receiving end. To tell JVM about the members who need not undergo serialization instead of being lost during transfer, a transient modifier comes into the picture.
Syntax:
private transient member1;
Code:
import java.io.*; class Demo implements Serializable { int x = 10; transient int y = 30; transient static int z = 40; transient final int d = 50; public static void main(String[] args) throws Exception { Demo input = new Demo(); FileOutputStream tos = new FileOutputStream("abc.txt"); ObjectOutputStream tin = new ObjectOutputStream(tos); tin.writeObject(input); FileInputStream fis = new FileInputStream("abc.txt"); ObjectInputStream ois = new ObjectInputStream(fis); Demo output = (Demo)ois.readObject(); System.out.println("x = " + output.x); System.out.println("y = " + output.y); System.out.println("z = " + output.z); System.out.println("d = " + output.d); } }
Output:
Non-access modifiers are the type of modifiers that tell JVM about the behavior of classes, methods, or variables defined and prepared accordingly. It also helps in synchronizing the flow as well as displaying similar results from operations being performed irrespective of the platform used for execution.
This is a guide to Non Access Modifiers in Java. Here we discuss the Types of Non Access Modifiersand their methods and code implementation in Java. You can also go through our other suggested articles to learn more –
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!