std::basic_ostream::basic_ostream
Материал из cppreference.com
|
|
Эта страница была переведена автоматически с английской версии вики используя Переводчик Google. Перевод может содержать ошибки и странные формулировки. Наведите курсор на текст, чтобы увидеть оригинал. Щёлкните здесь, чтобы увидеть английскую версию этой страницы. (Вы можете помочь в исправлении ошибок и улучшении перевода. Для инструкций перейдите по ссылке.) |
<metanoindex/>
<tbody> </tbody> explicit basic_ostream( std::basic_streambuf<CharT, Traits>* sb ); |
(1) | |
protected: basic_ostream( const basic_ostream& rhs ) = delete; |
(2) | |
protected: basic_ostream( basic_ostream&& rhs ); |
(3) | (начиная с C++11) |
1)
Создает
basic_ostream объектов, присвоение начальных значений базового класса, вызвав basic_ios::init(sb).Оригинал:
Constructs the
basic_ostream object, assigning initial values to the base class by calling basic_ios::init(sb).Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
2)
Конструктор копирования защищен, и удален. Выходные потоки не копируемым.
Оригинал:
The copy constructor is protected, and is deleted. Output streams are not copyable.
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
3)
Этот шаг конструктор использует
basic_ios<CharT, Traits>::move(rhs), чтобы переместить все basic_ios членов, за исключением rdbuf(), от rhs в *this. Этот шаг конструктор защищена: она называется по ходу конструкторов подвижных классов выходной поток std::basic_ofstream и std::basic_ostringstream, которые знают, как правильно двигаться связанных streambuffer.Оригинал:
The move constructor uses
basic_ios<CharT, Traits>::move(rhs) to move all basic_ios members, except for the rdbuf(), from rhs into *this. This move constructor is protected: it is called by the move constructors of movable output stream classes std::basic_ofstream and std::basic_ostringstream, which know how to correctly move the associated streambuffer.Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Параметры
| sb | — | streambuffer использовать в качестве выходной последовательности
Оригинал: streambuffer to use as output sequence Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. |
| rhs | — | basic_ostream для инициализации с
Оригинал: basic_ostream to initialize from Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. |
Пример
Запустить этот код
#include <sstream>
#include <utility>
#include <iostream>
int main()
{
// std::ostream myout(std::cout); // ERROR: copy ctor is deleted
std::ostream myout(std::cout.rdbuf()); // OK: shares buffer with cout
// std::ostream s2(std::move(std::ostringstream() << 7.1)); // ERROR: move constructor
// is protected
std::ostringstream s2(std::move(std::ostringstream() << 7.1)); // OK: move ctor called
// through the derived class
myout << s2.str() << '\n';
}
Вывод:
7.1