Ajout à un ObjectOutputStream : une solution
En Java, l'ajout à un ObjectOutputStream n'est pas intrinsèquement pris en charge. Tenter d'ajouter à un fichier existant à l'aide du standard ObjectOutputStream entraînera l'exception StreamCorruptedException lors de la lecture.
Pour surmonter cette limitation, on peut sous-classer ObjectOutputStream et remplacer sa méthode writeStreamHeader. Le writeStreamHeader modifié ne doit pas écrire d'en-tête mais plutôt réinitialiser le flux lors de l'écriture de l'objet initial.
Le code suivant démontre la création d'une classe AppendingObjectOutputStream :
public class AppendingObjectOutputStream extends ObjectOutputStream { public AppendingObjectOutputStream(OutputStream out) throws IOException { super(out); } @Override protected void writeStreamHeader() throws IOException { // do not write a header, but reset: this.reset(); } }
Pour utiliser cette classe, déterminer si le fichier historique cible existe. Si c’est le cas, instanciez AppendingObjectOutputStream pour ajouter des données sans écrire d’en-tête. Si le fichier n'existe pas, instanciez le ObjectOutputStream standard pour écrire un en-tête.
// Check if history file exists if (fileExists) { // Appendable stream ObjectOutputStream out = new AppendingObjectOutputStream(new FileOutputStream(filePath, true)); } else { // Standard stream ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream(filePath)); }
En utilisant AppendingObjectOutputStream, on peut ajouter avec succès des objets à un fichier historique existant, garantissant que tous les objets écrits peuvent être lus. dans le bon ordre.
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!