std::strstreambuf:: ~strstreambuf
| 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)
|
| Public member functions | ||||
|
strstreambuf::~strstreambuf
|
||||
| Protected member functions | ||||
|
virtual
~strstreambuf
(
)
;
|
(устарело в C++98)
(удалено в C++26) |
|
Уничтожает объект
std::strstreambuf
. Если объект управляет динамически выделенным буфером (состояние буфера "allocated") и если объект не заморожен, то освобождает буфер с использованием функции освобождения, предоставленной при создании, или
delete
[
]
если функция не была предоставлена.
Параметры
(нет)
Примечания
Этот деструктор обычно вызывается деструктором std::strstream .
Если
str()
был вызван для динамического
strstream
и
freeze(false)
не был вызван после этого, этот деструктор приводит к утечке памяти.
Пример
#include <iostream> #include <strstream> void* my_alloc(size_t n) { std::cout << "my_alloc(" << n << ") called\n"; return new char[n]; } void my_free(void* p) { std::cout << "my_free() called\n"; delete[] (char*)p; } int main() { { std::strstreambuf buf(my_alloc, my_free); std::ostream s(&buf); s << 1.23 << std::ends; std::cout << buf.str() << '\n'; buf.freeze(false); } // деструктор вызывается здесь, буфер освобождается { std::strstreambuf buf(my_alloc, my_free); std::ostream s(&buf); s << 1.23 << std::ends; std::cout << buf.str() << '\n'; // buf.freeze(false); } // деструктор вызывается здесь, утечка памяти! }
Вывод:
my_alloc(4096) called 1.23 my_free() called my_alloc(4096) called 1.23