Dans le domaine du codage, il devient souvent nécessaire de rediriger les données d'un OutputStream vers un InputStream. Cette conversion complexe, bien que moins simple que l'inverse, peut être réalisée grâce à l'utilisation habile des tuyaux.
Décoder la puissance des tuyaux
Java.io de Java. Les classes PipedInputStream et java.io.PipedOutputStream apparaissent comme les acteurs clés de ce processus de conversion. Ils établissent un pipeline unidirectionnel entre un OutputStream et un InputStream, permettant un transfert transparent de données sans encourir une surcharge de mémoire significative.
Code alimenté par Lambda pour une conversion sans effort
Ce qui suit L'extrait de code exploite les lambdas pour simplifier la conversion :
PipedInputStream in = new PipedInputStream(); final PipedOutputStream out = new PipedOutputStream(in); // in a background thread, write the given output stream to the // PipedOutputStream for consumption new Thread(() -> {originalOutputStream.writeTo(out);}).start();
Try-with-Resources : une approche élégante
Alternativement, try-with-resources fournit une syntaxe élégante pour la gestion des ressources :
PipedInputStream in = new PipedInputStream(); new Thread(new Runnable() { public void run () { // try-with-resources here // placing the try block outside the Thread will prematurely close the PipedOutputStream try (final PipedOutputStream out = new PipedOutputStream(in)) { // write the original OutputStream to the PipedOutputStream originalByteArrayOutputStream.writeTo(out); } catch (IOException e) { // logging and exception handling should go here } } }).start();
Considérations supplémentaires
Dans les cas où vous manquez de contrôle sur la création de OutputStream, vous pouvez rencontrer l'exception ClosedPipeException. Pour résoudre ce problème, inversez les constructeurs :
PipedInputStream in = new PipedInputStream(out); new Thread(() -> {originalOutputStream.writeTo(out);}).start();
Avantages de la conversion canalisée
Cette méthode de conversion excelle en termes d'efficacité mémoire. Contrairement à d’autres techniques qui créent des copies de données en double, les canaux établissent simplement une connexion entre les flux sans consommation de mémoire supplémentaire. De plus, l'exécution asynchrone dans un thread séparé garantit une latence minimale et une utilisation réduite des ressources.
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!