Standard library header <ios>
From cppreference.net
Этот заголовок является частью библиотеки Ввода/Вывода .
Включения |
||
| Форвардные объявления всех классов библиотеки ввода/вывода | ||
Классы |
||
|
управляет флагами форматирования и исключениями ввода/вывода
(класс) |
||
|
управляет произвольным буфером потока
(шаблон класса) |
||
| std::ios | std:: basic_ios < char > (определение типа) | |
| std::wios | std:: basic_ios < wchar_t > (определение типа) | |
|
представляет абсолютную позицию в потоке или файле
(шаблон класса) |
||
|
(C++11)
|
коды ошибок потоков ввода-вывода
(перечисление) |
|
|
расширяет признак типа
std::is_error_code_enum
для идентификации кодов ошибок потокового ввода-вывода
(специализация шаблона класса) |
||
|
представляет относительную позицию в файле/потоке (смещение от fpos), достаточную для представления любого размера файла
(typedef) |
||
|
представляет количество символов, переданных в операции ввода-вывода, или размер буфера ввода-вывода
(typedef) |
||
Функции |
||
|
(C++11)
|
идентифицирует категорию ошибок iostream
(функция) |
|
|
(C++11)
|
создает код ошибки iostream
(функция) |
|
|
создает условие ошибки ввода-вывода
(функция) |
||
|
переключает между текстовым и числовым представлением булевых значений
(функция) |
||
|
управляет использованием префикса для указания системы счисления
(функция) |
||
|
управляет тем, всегда ли включать десятичную точку в представлении чисел с плавающей запятой
(функция) |
||
управляет отображением знака
+
для неотрицательных чисел
(функция) |
||
|
управляет пропуском начальных пробельных символов при вводе
(функция) |
||
|
управляет использованием символов верхнего регистра в некоторых выходных форматах
(функция) |
||
|
управляет тем, сбрасывается ли вывод после каждой операции
(функция) |
||
|
задает расположение символов заполнения
(функция) |
||
|
изменяет основание системы счисления для целочисленного ввода/вывода
(функция) |
||
|
(C++11)
(C++11)
|
изменяет форматирование, используемое для операций ввода-вывода с плавающей точкой
(функция) |
|
Синопсис
#include <iosfwd> namespace std { using streamoff = /* определяемый реализацией */; using streamsize = /* определяемый реализацией */; template<class StateT> class fpos; class ios_base; template<class CharT, class Traits = char_traits<CharT>> class basic_ios; // манипуляторы ios_base& boolalpha (ios_base& str); ios_base& noboolalpha(ios_base& str); ios_base& showbase (ios_base& str); ios_base& noshowbase (ios_base& str); ios_base& showpoint (ios_base& str); ios_base& noshowpoint(ios_base& str); ios_base& showpos (ios_base& str); ios_base& noshowpos (ios_base& str); ios_base& skipws (ios_base& str); ios_base& noskipws (ios_base& str); ios_base& uppercase (ios_base& str); ios_base& nouppercase(ios_base& str); ios_base& unitbuf (ios_base& str); ios_base& nounitbuf (ios_base& str); // поле выравнивания ios_base& internal (ios_base& str); ios_base& left (ios_base& str); ios_base& right (ios_base& str); // поле системы счисления ios_base& dec (ios_base& str); ios_base& hex (ios_base& str); ios_base& oct (ios_base& str); // поле формата чисел с плавающей точкой ios_base& fixed (ios_base& str); ios_base& scientific (ios_base& str); ios_base& hexfloat (ios_base& str); ios_base& defaultfloat(ios_base& str); // обработка ошибок enum class io_errc { stream = 1 }; template<> struct is_error_code_enum<io_errc> : public true_type { }; error_code make_error_code(io_errc e) noexcept; error_condition make_error_condition(io_errc e) noexcept; const error_category& iostream_category() noexcept; }
Класс std::ios_base
namespace std { class ios_base { public: class failure; // см. описание // fmtflags using fmtflags = /*bitmask-type-1*/; static constexpr fmtflags boolalpha = /* не указано */; static constexpr fmtflags dec = /* не указано */; static constexpr fmtflags fixed = /* не указано */; static constexpr fmtflags hex = /* не указано */; static constexpr fmtflags internal = /* не указано */; static constexpr fmtflags left = /* не указано */; static constexpr fmtflags oct = /* не указано */; static constexpr fmtflags right = /* не указано */; static constexpr fmtflags scientific = /* не указано */; static constexpr fmtflags showbase = /* не указано */; static constexpr fmtflags showpoint = /* не указано */; static constexpr fmtflags showpos = /* не указано */; static constexpr fmtflags skipws = /* не указано */; static constexpr fmtflags unitbuf = /* не указано */; static constexpr fmtflags uppercase = /* не указано */; static constexpr fmtflags adjustfield = /* см. описание */; static constexpr fmtflags basefield = /* см. описание */; static constexpr fmtflags floatfield = /* см. описание */; // iostate using iostate = /*bitmask-type-2*/; static constexpr iostate badbit = /* не указано */; static constexpr iostate eofbit = /* не указано */; static constexpr iostate failbit = /* не указано */; static constexpr iostate goodbit = /* см. описание */; // режим открытия using openmode = /*bitmask-type-3*/; static constexpr openmode app = /* не указано */; static constexpr openmode ate = /* не указано */; static constexpr openmode binary = /* не указано */; static constexpr openmode in = /* не указано */; static constexpr openmode out = /* не указано */; static constexpr openmode trunc = /* не указано */; static constexpr openmode noreplace = /* не указано */ // seekdir using seekdir = /*bitmask-type-4*/; static constexpr seekdir beg = /* не указано */; static constexpr seekdir cur = /* не указано */; static constexpr seekdir end = /* не указано */; class Init; // состояние флагов форматирования fmtflags flags() const; fmtflags flags(fmtflags fmtfl); fmtflags setf(fmtflags fmtfl); fmtflags setf(fmtflags fmtfl, fmtflags mask); void unsetf(fmtflags mask); streamsize precision() const; streamsize precision(streamsize prec); streamsize width() const; streamsize width(streamsize wide); // локали locale imbue(const locale& loc); locale getloc() const; // storage static int xalloc(); long& iword(int idx); void*& pword(int idx); // деструктор virtual ~ios_base(); // колбэки enum event { erase_event, imbue_event, copyfmt_event }; using event_callback = void (*)(event, ios_base&, int idx); void register_callback(event_callback fn, int idx); ios_base(const ios_base&) = delete; ios_base& operator=(const ios_base&) = delete; static bool sync_with_stdio(bool sync = true); protected: ios_base(); private: static int index; // только для демонстрации long* iarray; // только для демонстрации void** parray; // только для демонстрации }; }
Класс std::ios_base::failure
namespace std { class ios_base::failure : public system_error { public: explicit failure(const string& msg, const error_code& ec = io_errc::stream); explicit failure(const char* msg, const error_code& ec = io_errc::stream); }; }
Класс std::ios_base::Init
namespace std { class ios_base::Init { public: Init(); Init(const Init&) = default; ~Init(); Init& operator=(const Init&) = default; private: static int init_cnt; // только для демонстрации }; }
Шаблон класса std::fpos
namespace std { template<class StateT> class fpos { public: // члены StateT state() const; void state(stateT); private; StateT st; // только для демонстрации }; }
Шаблон класса std::basic_ios
namespace std { template<class CharT, class Traits = char_traits<CharT>> class basic_ios : public ios_base { public: using char_type = CharT; using int_type = typename Traits::int_type; using pos_type = typename Traits::pos_type; using off_type = typename Traits::off_type; using traits_type = Traits; // функции флагов explicit operator bool() const; bool operator!() const; iostate rdstate() const; void clear(iostate state = goodbit); void setstate(iostate state); bool good() const; bool eof() const; bool fail() const; bool bad() const; iostate exceptions() const; void exceptions(iostate except); // конструктор/деструктор explicit basic_ios(basic_streambuf<CharT, Traits>* sb); virtual ~basic_ios(); // члены basic_ostream<CharT, Traits>* tie() const; basic_ostream<CharT, Traits>* tie(basic_ostream<CharT, Traits>* tiestr); basic_streambuf<CharT, Traits>* rdbuf() const; basic_streambuf<CharT, Traits>* rdbuf(basic_streambuf<CharT, Traits>* sb); basic_ios& copyfmt(const basic_ios& rhs); char_type fill() const; char_type fill(char_type ch); locale imbue(const locale& loc); char narrow(char_type c, char dfault) const; char_type widen(char c) const; basic_ios(const basic_ios&) = delete; basic_ios& operator=(const basic_ios&) = delete; protected: basic_ios(); void init(basic_streambuf<CharT, Traits>* sb); void move(basic_ios& rhs); void move(basic_ios&& rhs); void swap(basic_ios& rhs) noexcept; void set_rdbuf(basic_streambuf<CharT, Traits>* sb); }; }
Отчеты о дефектах
Следующие отчеты об изменениях поведения, влияющие на дефекты, были применены ретроактивно к ранее опубликованным стандартам C++.
| DR | Применяется к | Поведение в опубликованной версии | Корректное поведение |
|---|---|---|---|
| LWG 35 | C++98 | прототипы unitbuf и nounitbuf отсутствовали в синопсисе | добавлены |
| LWG 78 | C++98 |
тип параметра
fn
функции
ios_base::register_callback
в синопсисе был указан неверно как
event_call_back
|
исправлено на
event_callback
|