Maison > Java > javaDidacticiel > Comment puis-je gérer les exceptions vérifiées émises par Java 8 Lambdas et Streams ?

Comment puis-je gérer les exceptions vérifiées émises par Java 8 Lambdas et Streams ?

DDD
Libérer: 2024-12-10 20:36:10
original
262 Les gens l'ont consulté

How Can I Handle Checked Exceptions Thrown from Java 8 Lambdas and Streams?

Lancement d'exceptions vérifiées à partir de Java 8 Lambdas et Streams

Contrairement aux exceptions d'exécution, les exceptions vérifiées nécessitent une gestion explicite dans le code Java. Cependant, lors de l'utilisation d'expressions et de flux lambda, les développeurs peuvent rencontrer des difficultés pour lancer des exceptions vérifiées. Cet article explore les limitations et les solutions potentielles pour gérer les exceptions vérifiées dans ces contextes.

La limitation :

La syntaxe Java 8 actuelle ne fournit pas de mécanisme direct pour lancer la vérification exceptions provenant des expressions lambda utilisées dans les flux. L'extrait de code suivant illustre l'erreur de compilation rencontrée :

import java.util.List;
import java.util.stream.Stream;

public class CheckedStream {
    public List<Class> getClasses() throws ClassNotFoundException {
        Stream.of("java.lang.Object", "java.lang.Integer", "java.lang.String")
              .map(className -> Class.forName(className))
              .collect(Collectors.toList());
    }
}
Copier après la connexion

Le problème vient du fait que les interfaces fonctionnelles utilisées dans les flux, telles que Function et Stream, ne déclarent pas de paramètres de type pour prendre en charge le lancement d'exceptions vérifiées. Par conséquent, le compilateur ne peut pas déduire le type d'exception précis et signale une erreur de compilation.

Le dilemme Oracle :

L'omission de cette fonctionnalité est attribuée à un oubli lors de la conception des interfaces fonctionnelles de Java 8. La communauté Java a largement critiqué Oracle pour cette limitation, beaucoup affirmant qu'il s'agit d'un bug important dans l'API et d'un inconvénient des exceptions vérifiées en général.

Alternatives et solutions de contournement :

Bien que Java 8 ne prenne pas directement en charge le lancement d'exceptions vérifiées à partir de lambdas, il existe des solutions de contournement disponible :

1. Encapsulation des exceptions vérifiées dans les exceptions d'exécution :

Cette approche consiste à envelopper les exceptions vérifiées dans des exceptions d'exécution, puis à lancer les exceptions encapsulées dans des expressions lambda.

// Import the necessary class.
import java.io.IOException;

// Create a wrapper class to wrap checked exceptions.
public class CheckedExceptionWrapper {

    public static void main(String[] args) {
        // Create a stream of strings.
        Stream<String> stream = Stream.of("file1.txt", "file2.txt", "file3.txt");

        // Map the stream using a lambda that wraps checked exceptions.
        stream = stream.map(file -> {
            try {
                // Read the file.
                FileReader reader = new FileReader(file);
                reader.close();
                return file;
            } catch (IOException e) {
                // Wrap the checked exception in a runtime exception.
                throw new RuntimeException(e);
            }
        });

        // Collect the results.
        List<String> files = stream.collect(Collectors.toList());
    }
}
Copier après la connexion

2. Utilisation du fournisseur vérifié :

L'interface CheckedSupplier de la bibliothèque guava vous permet de créer des fournisseurs qui génèrent des exceptions vérifiées. Vous pouvez utiliser cette interface pour envelopper le code de lancement d'exceptions vérifié dans des expressions lambda.

// Import the necessary class.
import com.google.common.base.CheckedSupplier;

// Create a checked supplier that throws a checked exception.
CheckedSupplier<String> supplier = () -> {
    // Code that throws a checked exception.
    throw new RuntimeException();
};

// Get the result from the supplier.
try {
    String result = supplier.get();
} catch (Exception e) {
    // Handle the exception.
}
Copier après la connexion

3. Réécriture du code pour éviter d'utiliser des exceptions vérifiées :

Au lieu d'utiliser des exceptions vérifiées, envisagez de réécrire votre code pour gérer les erreurs d'une manière différente. Par exemple, vous pouvez utiliser la classe Optionnel pour représenter des valeurs facultatives ou lancer des exceptions non vérifiées et les gérer à l'aide de blocs try-catch.

4. Utilisation des blocs Catch and Throw :

Cette approche est simple mais peut rendre votre code verbeux et difficile à lire.

// Example for Java 7 with try/catch
try {
    // Code that throws a checked exception.
    throw new RuntimeException();
} catch (Exception e) {
    // Handle the exception.
}
Copier après la connexion

Conclusion :

Bien que la syntaxe de Java 8 ne prenne pas directement en charge le lancement d'exceptions vérifiées à partir des lambdas et des flux, des solutions de contournement sont disponibles. Réfléchissez attentivement à l'approche appropriée à votre situation spécifique.

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!

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