Partager via


strstreambuf::freeze

Rend une mémoire tampon du flux non disponible via des opérations de mémoire tampon du flux.

void freeze(
   bool _Freezeit = true
);

Paramètres

  • _Freezeit
    bool indiquant si vous souhaitez que le flux de figer.

Notes

Si _Freezeit est true, la fonction modifie l'état stocké d' strstreambuf pour que l'ordre d'exécution des instructions figé.Sinon, il fait l'ordre d'exécution des instructions non figé.

streptocoque implique freeze.

[!REMARQUE]

Une mémoire tampon gelée n'est pas libérée pendant la destruction d' strstreambuf .Vous devez dégeler la mémoire tampon avant d'être libérée pour éviter une fuite de mémoire.

Exemple

// strstreambuf_freeze.cpp
// compile with: /EHsc

#include <iostream>
#include <strstream>

using namespace std;

void report(strstream &x)
{
    if (!x.good())
        cout << "stream bad" << endl;
    else
        cout << "stream good" << endl;
}

int main()
{
    strstream x;

    x << "test1";
    cout << "before freeze: ";
    report(x);

    // Calling str freezes stream.
    cout.write(x.rdbuf()->str(), 5) << endl;
    cout << "after freeze: ";
    report(x);

    // Stream is bad now, wrote on frozen stream
    x << "test1.5";
    cout << "after write to frozen stream: ";
    report(x);

    // Unfreeze stream, but it is still bad
    x.rdbuf()->freeze(false);
    cout << "after unfreezing stream: ";
    report(x);

    // Clear stream
    x.clear();
    cout << "after clearing stream: ";
    report(x);

    x << "test3";
    cout.write(x.rdbuf()->str(), 10) << endl;

    // Clean up.  Failure to unfreeze stream will cause a
    // memory leak.
    x.rdbuf()->freeze(false);
}
  

Configuration requise

en-tête : <strstream>

l'espace de noms : DST

Voir aussi

Référence

strstreambuf Class

programmation iostream

conventions d'iostreams