Maison  >  Article  >  développement back-end  >  Pourquoi `std::fstream::open()` génère-t-il une erreur « Aucun fichier ou répertoire de ce type » lors de la création d'un fichier ?

Pourquoi `std::fstream::open()` génère-t-il une erreur « Aucun fichier ou répertoire de ce type » lors de la création d'un fichier ?

Mary-Kate Olsen
Mary-Kate Olsenoriginal
2024-11-01 04:22:27321parcourir

Why Does `std::fstream::open()` Throw a

Problème de création de fichiers avec std::fstream

Question :

Lors de l'utilisation de std : :fstream pour les E/S de fichier, rencontrant un message d'erreur « Aucun fichier ou répertoire de ce type » lors de la tentative de création d'un fichier s'il n'existe pas déjà. Plus précisément, l'extrait de code ci-dessous est à l'origine du problème :

<code class="cpp">std::fstream my_stream;
my_stream.open("my_file_name", std::fstream::binary | std::fstream::in | std::fstream::out);
if (!my_stream)
    std::cout << "error" << strerror(errorno);</code>

Comment ce problème peut-il être résolu pour garantir la création de fichiers lorsque cela est nécessaire ?

Réponse :

La fonction fstream::open() nécessite un fichier inexistant si std::fstream::in est spécifié dans l'argument mode. Pour résoudre le problème, supprimez std::fstream::in des indicateurs de mode ou ajoutez std::fstream::trunc à côté des indicateurs existants.

<code class="cpp">// Remove std::fstream::in
std::fstream my_stream;
my_stream.open("my_file_name", std::fstream::binary | std::fstream::out);

// Add std::fstream::trunc
std::fstream my_stream;
my_stream.open("my_file_name", std::fstream::binary | std::fstream::in | std::fstream::out | std::fstream::trunc);</code>

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