Maison >Java >javaDidacticiel >Comment puis-je gérer de manière fiable les flux d'entrée/sortie d'un processus Java pour éviter les ruptures de canal et garantir une sortie cohérente ?

Comment puis-je gérer de manière fiable les flux d'entrée/sortie d'un processus Java pour éviter les ruptures de canal et garantir une sortie cohérente ?

DDD
DDDoriginal
2024-12-29 12:16:12203parcourir

How Can I Reliably Manage Input/Output Streams from a Java Process to Avoid Broken Pipes and Ensure Consistent Output?

Communication des flux d'entrée/sortie de processus en Java

En Java, l'accès aux flux d'entrée ou de sortie à partir d'un processus en cours d'exécution est essentiel pour l'exécution des commandes et échange de données. Toutefois, des pièges peuvent survenir lors de la gestion efficace de ces flux.

Points forts des problèmes

Vous avez demandé pourquoi votre exemple de code rencontre une erreur de canal cassé et pourquoi les flux de sortie suivants ne fonctionnent pas. après la première lecture. Le problème réside dans l'approche du code pour manipuler les flux d'entrée et de sortie du processus shell.

Solutions

Pour résoudre ce problème, envisagez les étapes suivantes :

  1. Utiliser ProcessBuilder : Remplacez le code qui initialise la variable "process" par ProcessBuilder, qui offre un meilleur contrôle sur la gestion des processus. Utilisez "ProcessBuilder.redirectErrorStream(true)" pour rediriger à la fois la sortie standard et l'erreur vers un seul flux.
  2. Brisez l'habitude de la boucle : La boucle qui lit à partir du lecteur (stdout) se termine uniquement lorsque le processus est terminé. Cela signifie qu'il se bloquera si aucune entrée supplémentaire n'est fournie.
  3. Introduisez un délimiteur de commande : Pour récupérer de manière fiable le résultat de plusieurs commandes, envisagez d'adopter une technique de « chaîne magique ». Introduisez une chaîne unique (par exemple, "--EOF--") qui marque la fin de la sortie de chaque commande.
  4. Ajuster l'écriture d'entrée : Pour envoyer une commande avec le délimiteur, ajoutez le commande avec "&& echo --EOF--". Si "exit" est saisi, envoyez "exit" à la place.

Explication

Ces modifications résolvent l'erreur de canal cassé et permettent d'exécuter plusieurs commandes avec récupération de sortie cohérente. Le délimiteur « chaîne magique » garantit que les opérations de lecture se terminent toujours par le délimiteur, empêchant ainsi le blocage.

Malgré ces ajustements, certaines limitations subsistent :

  • Les commandes d'invite de saisie de l'utilisateur peuvent provoquer le programme à bloquer.
  • L'hypothèse d'une sortie terminée par une nouvelle ligne peut introduire problèmes.
  • La gestion des « sorties » a été améliorée, mais d'autres cas d'entrée spéciaux peuvent nécessiter une considération supplémentaire.

En incorporant ces suggestions, votre code peut gérer efficacement les flux d'entrée et de sortie de un processus en cours d'exécution, ouvrant la voie à une tâche planifiée stable et fiable qui exécute des commandes périodiquement.

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!

Déclaration:
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