So vermeiden Sie eine Nullzeigerausnahme in Java
Niemand mag eine NullPointerException! Gibt es eine Möglichkeit, sie zu vermeiden? Vielleicht. .
In diesem Artikel werden die folgenden Technologien besprochen
1. Optionaler Typ (neu eingeführt in Java 8)
2. Optional Klasse in Java 8
Was ist das?
1. Ein neu eingeführter Typ in Java 8
2. Er wird als Wrapper für ein Objekt eines bestimmten Typs oder für Szenarien verwendet, in denen kein Objekt (null) vorhanden ist.
Einfach Kurz gesagt, es ist eine bessere Alternative für den Umgang mit Nullwerten (Warnung: Es ist auf den ersten Blick möglicherweise nicht so offensichtlich)
Grundlegende Verwendung
Es ist ein Typ (eine Klasse) – also , wie können Sie eine Instanz dieses Typs erstellen?
Verwenden Sie einfach die drei statischen Methoden:
Einfach und klar – erstellen Sie eine Instanz mit diesem optionalen Wrapper. Denken Sie daran: Wenn dieser Wert null ist, wird NPE ausgelöst!public static Optional<String> stringOptional(String input) { return Optional.of(input); }
public static Optional<String> stringNullableOptional(String input) { if (!new Random().nextBoolean()) { input = null; } return Optional.ofNullable(input); }
public static Optional<String> emptyOptional() { return Optional.empty(); }
Okay, wie kann man dann Optional konsumieren/verwenden?
Der einfache Weg besteht darin, zu überprüfen, ob der optionale Wrapper tatsächlich einen Wert hat (mit der Methode isPresent) – Sie werden sich fragen, welchen Vorteil es im Vergleich zur Verwendung von if(myObj != null) hat. Keine Sorge, ich werde das klar erklären.public static void consumingOptional() { Optional<String> wrapped = Optional.of("aString"); if (wrapped.isPresent()) { System.out.println("Got string - " + wrapped.get()); } else { System.out.println("Gotcha !"); } }
public static void consumingNullableOptional() { String input = null; if (new Random().nextBoolean()) { input = "iCanBeNull"; } Optional<String> wrapped = Optional.ofNullable(input); System.out.println(wrapped.orElse("default")); }
public static void consumingEmptyOptional() { String input = null; if (new Random().nextBoolean()) { input = "iCanBeNull"; } Optional<String> wrapped = Optional.ofNullable(input); System.out.println(wrapped.orElseGet( () -> { return "defaultBySupplier"; } )); }
Wie auch immer, der offensichtliche Unterschied zwischen diesen beiden Methoden sind ihre Parameter – Sie können Lambda-Ausdrücke anstelle von Instanzen von Supplier verwenden, um dies zu erreichen (eine funktionale Schnittstelle)
Warum ist die Verwendung von Optional besser? als die übliche Nullprüfung?
1. Der größte Vorteil der Verwendung von Optional besteht darin, dass Sie Ihre Absicht klarer ausdrücken können – die Rückgabe eines Nullwerts führt dazu, dass Verbraucher verwirrt werden (wenn NPE auftritt), ob dies absichtlich zurückgegeben wird, daher müssen Sie dies überprüfen Javadoc zur weiteren Positionierung. Die Verwendung von Optional ist recht einfach.
2. Mit Optional können Sie NPE vollständig vermeiden – wie oben erwähnt, kann uns die Verwendung von Optional.ofNullable, orElse und orElseGet von NPE fernhalten.
Ein weiterer Retter!
Schauen Sie sich dieses Code-Snippet an
Welches könnte leer sein?package com.abhirockzz.wordpress.npesaviors; import java.util.Map; import java.util.Objects; public class UsingObjects { String getVal(Map<String, String> aMap, String key) { return aMap.containsKey(key) ? aMap.get(key) : null; } public static void main(String[] args) { UsingObjects obj = new UsingObjects(); obj.getVal(null, "dummy"); } }
1.Map-Objekt
2.Der für die Suche verwendete Schlüssel3.Die Instanz des Methodenaufrufs
Wenn ein NPE ausgelöst wird, wie können wir dann feststellen, um welches es sich handelt? ist? null?
package com.abhirockzz.wordpress.npesaviors; import java.util.Map; import java.util.Objects; public class UsingObjects { String getValSafe(Map<String, String> aMap, String key) { Map<String, String> safeMap = Objects.requireNonNull(aMap, "Map is null"); String safeKey = Objects.requireNonNull(key, "Key is null"); return safeMap.containsKey(safeKey) ? safeMap.get(safeKey) : null; } public static void main(String[] args) { UsingObjects obj = new UsingObjects(); obj.getValSafe(null, "dummy"); } }
1. Wenn das Objekt nicht null ist, gibt es sich selbst zurück
2 Wenn der Wert null ist, wird die zurückgegebene NPE die angegebene Nachricht haben
Warum ist es besser als if(myObj!=null)?
Die Stack-Trace-Informationen, die Sie sehen, zeigen deutlich den Methodenaufruf von Objects.requireNonNull. In Kombination mit Ihrem eigenen Fehlerprotokoll können Sie so das Problem schneller lokalisieren. . . Zumindest ist es meiner Meinung nach schneller.
Sie können auch Ihren eigenen Validator anpassen, beispielsweise einen einfachen Validator implementieren, um sicherzustellen, dass keine Nullwerte vorhanden sind.
Lassen Sie nicht zu, dass NPE an der falschen Stelle zur Belastung wird. Wir verfügen über viele Tools, um NPEs besser zu bekämpfen und sie sogar vollständig zu beseitigen!import java.util.Collections; import java.util.List; import java.util.Objects; import java.util.function.Predicate; public class RandomGist { public static <T> T requireNonEmpty(T object, Predicate<T> predicate, String msgToCaller){ Objects.requireNonNull(object); Objects.requireNonNull(predicate); if (predicate.test(object)){ throw new IllegalArgumentException(msgToCaller); } return object; } public static void main(String[] args) { //Usage 1: an empty string (intentional) String s = ""; System.out.println(requireNonEmpty(Objects.requireNonNull(s), (s1) -> s1.isEmpty() , "My String is Empty!")); //Usage 2: an empty List (intentional) List list = Collections.emptyList(); System.out.println(requireNonEmpty(Objects.requireNonNull(list), (l) -> l.isEmpty(), "List is Empty!").size()); //Usage 3: an empty User (intentional) User user = new User(""); System.out.println(requireNonEmpty(Objects.requireNonNull(user), (u) -> u.getName().isEmpty(), "User is Empty!")); } private static class User { private String name; public User(String name){ this.name = name; } public String getName(){ return name; } } }
Weitere verwandte Artikel zu Methoden zur Vermeidung von Nullzeigerausnahmen in Java finden Sie auf der chinesischen PHP-Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Mit der Klassenbelastung von Java wird das Laden, Verknüpfen und Initialisieren von Klassen mithilfe eines hierarchischen Systems mit Bootstrap-, Erweiterungs- und Anwendungsklassenloadern umfasst. Das übergeordnete Delegationsmodell stellt sicher

In dem Artikel wird in der Implementierung von mehrstufigem Caching in Java mithilfe von Koffein- und Guava-Cache zur Verbesserung der Anwendungsleistung erläutert. Es deckt die Einrichtungs-, Integrations- und Leistungsvorteile sowie die Bestrafung des Konfigurations- und Räumungsrichtlinienmanagements ab

In diesem Artikel wird die Integration der funktionalen Programmierung in Java unter Verwendung von Lambda -Ausdrücken, Streams -API, Methodenreferenzen und optional untersucht. Es zeigt Vorteile wie eine verbesserte Lesbarkeit der Code und die Wartbarkeit durch SUKTIVE UND VERUSNAHMETALITÄT

In dem Artikel werden mit JPA für Objektrelationszuordnungen mit erweiterten Funktionen wie Caching und faulen Laden erläutert. Es deckt Setup, Entity -Mapping und Best Practices zur Optimierung der Leistung ab und hebt potenzielle Fallstricke hervor. [159 Charaktere]

In dem Artikel werden Maven und Gradle für Java -Projektmanagement, Aufbau von Automatisierung und Abhängigkeitslösung erörtert, die ihre Ansätze und Optimierungsstrategien vergleichen.

In diesem Artikel werden die NIO-API von Java für nicht blockierende E/A erläutert, wobei Selektoren und Kanäle verwendet werden, um mehrere Verbindungen effizient mit einem einzelnen Thread zu verarbeiten. Es beschreibt den Prozess, die Vorteile (Skalierbarkeit, Leistung) und mögliche Fallstricke (Komplexität,

In dem Artikel werden benutzerdefinierte Java -Bibliotheken (JAR -Dateien) mit ordnungsgemäßem Versioning- und Abhängigkeitsmanagement erstellt und verwendet, wobei Tools wie Maven und Gradle verwendet werden.

In diesem Artikel wird die Socket-API von Java für die Netzwerkkommunikation beschrieben, die das Setup des Client-Servers, die Datenbearbeitung und entscheidende Überlegungen wie Ressourcenverwaltung, Fehlerbehandlung und Sicherheit abdeckt. Es untersucht auch die Leistungsoptimierungstechniken, ich
