std::ostrstream:: ~ostrstream
From cppreference.net
<
cpp
|
io
|
ostrstream
C++
Input/output library
| I/O manipulators | ||||
| Print functions (C++23) | ||||
| C-style I/O | ||||
| Buffers | ||||
|
(C++23)
|
||||
|
(
C++98/26*
)
|
||||
|
(C++20)
|
||||
| Streams | ||||
| Abstractions | ||||
| File I/O | ||||
| String I/O | ||||
| Array I/O | ||||
|
(C++23)
|
||||
|
(C++23)
|
||||
|
(C++23)
|
||||
|
(
C++98/26*
)
|
||||
|
(
C++98/26*
)
|
||||
|
(
C++98/26*
)
|
||||
| Synchronized Output | ||||
|
(C++20)
|
||||
| Types | ||||
| Error category interface | ||||
|
(C++11)
|
||||
|
(C++11)
|
std::ostrstream
| Member functions | ||||
|
ostrstream::~ostrstream
|
||||
|
virtual
~ostrstream
(
)
;
|
(obsolète en C++98)
(supprimé en C++26) |
|
Détruit un objet std::ostrstream , ce qui détruit également le membre std::strstreambuf , ce qui peut appeler la fonction de désallocation si le tampon sous-jacent était alloué dynamiquement et non gelé.
Paramètres
(aucun)
Notes
Si
str()
a été appelé sur un
ostrstream
dynamique et que
freeze(false)
n'a pas été appelé après cela, ce destructeur provoque une fuite de mémoire.
Exemple
Exécuter ce code
#include <iostream> #include <strstream> int main() { { std::ostrstream s; // tampon dynamique s << 1.23; std::cout << s.str() << '\n'; s.freeze(false); } // destructeur appelé, tampon désalloué { std::ostrstream s; s << 1.23; std::cout << s.str() << '\n'; // buf.freeze(false); } // destructeur appelé, fuite mémoire }
Sortie :
1.23 1.23