Namespaces
Variants

std:: basic_istream

From cppreference.net
< cpp ‎ | io
Определено в заголовочном файле <istream>
template <

class CharT,
class Traits = std:: char_traits < CharT >

> class basic_istream : virtual public std:: basic_ios < CharT, Traits >

Шаблон класса basic_istream предоставляет поддержку операций высокоуровневого ввода для символьных потоков. Поддерживаемые операции включают форматированный ввод (например, целочисленные значения или символы и строки символов, разделенные пробелами) и неформатированный ввод (например, необработанные символы и массивы символов). Эта функциональность реализована на основе интерфейса, предоставляемого базовым классом basic_streambuf , доступ к которому осуществляется через базовый класс basic_ios . Единственным не унаследованным элементом данных basic_istream в большинстве реализаций является значение, возвращаемое basic_istream::gcount() .

cpp/io/ios base cpp/io/basic ios std-basic istream-inheritance.svg

Диаграмма наследования

Предоставлены несколько typedef для распространённых символьных типов:

Определено в заголовочном файле <istream>
Тип Определение
std::istream std :: basic_istream < char >
std::wistream std :: basic_istream < wchar_t >

Содержание

Глобальные объекты

Стандартная библиотека предоставляет два глобальных объекта basic_istream.

Определено в заголовке <iostream>
читает из стандартного потока ввода C stdin
(глобальный объект)

Типы членов

Тип члена Определение
char_type CharT
traits_type Traits ; программа некорректна, если Traits::char_type не является CharT .
int_type Traits::int_type
pos_type Traits::pos_type
off_type Traits::off_type

Функции-члены

создает объект
(public member function)
[virtual]
уничтожает объект
(virtual public member function)
(C++11)
перемещает присваивание из другого basic_istream
(protected member function)
Форматированный ввод
извлекает форматированные данные
(public member function)
Неформатированный ввод
извлекает символы
(public member function)
читает следующий символ без его извлечения
(public member function)
возвращает символ обратно в поток
(public member function)
помещает символ во входной поток
(public member function)
извлекает символы до нахождения заданного символа
(public member function)
извлекает и отбрасывает символы до нахождения заданного символа
(public member function)
извлекает блоки символов
(public member function)
извлекает уже доступные блоки символов
(public member function)
возвращает количество символов, извлеченных последней операцией неформатированного ввода
(public member function)
Позиционирование
возвращает индикатор позиции ввода
(public member function)
устанавливает индикатор позиции ввода
(public member function)
Прочие операции
синхронизирует с базовым устройством хранения
(public member function)
(C++11)
обменивает объекты потоков, кроме связанного буфера
(protected member function)

Классы-члены

реализует базовую логику для подготовки потока к операциям ввода
(публичный класс-член)

Функции, не являющиеся членами класса

извлекает символы и массивы символов
(шаблон функции)

Унаследовано от std:: basic_ios

Типы членов

Тип члена Определение
char_type CharT
traits_type Traits
int_type Traits::int_type
pos_type Traits::pos_type
off_type Traits::off_type

Функции-члены

Функции состояния
проверяет, что ошибок не произошло, т.е. операции ввода-вывода доступны
(публичная функция-член std::basic_ios<CharT,Traits> )
проверяет, достигнут ли конец файла
(публичная функция-член std::basic_ios<CharT,Traits> )
проверяет, произошла ли ошибка
(публичная функция-член std::basic_ios<CharT,Traits> )
проверяет, произошла ли неустранимая ошибка
(публичная функция-член std::basic_ios<CharT,Traits> )
проверяет, произошла ли ошибка (синоним fail() )
(публичная функция-член std::basic_ios<CharT,Traits> )
проверяет, что ошибок не произошло (синоним ! fail() )
(публичная функция-член std::basic_ios<CharT,Traits> )
возвращает флаги состояния
(публичная функция-член std::basic_ios<CharT,Traits> )
устанавливает флаги состояния
(публичная функция-член std::basic_ios<CharT,Traits> )
изменяет флаги состояния
(публичная функция-член std::basic_ios<CharT,Traits> )
Форматирование
копирует информацию о форматировании
(публичная функция-член std::basic_ios<CharT,Traits> )
управляет символом-заполнителем
(публичная функция-член std::basic_ios<CharT,Traits> )
Прочие
управляет маской исключений
(публичная функция-член std::basic_ios<CharT,Traits> )
устанавливает локаль
(публичная функция-член std::basic_ios<CharT,Traits> )
управляет связанным буфером потока
(публичная функция-член std::basic_ios<CharT,Traits> )
управляет связанным потоком
(публичная функция-член std::basic_ios<CharT,Traits> )
сужает символы
(публичная функция-член std::basic_ios<CharT,Traits> )
расширяет символы
(публичная функция-член std::basic_ios<CharT,Traits> )

Унаследовано от std:: ios_base

Функции-члены

Форматирование
управляет флагами формата
(публичная функция-член std::ios_base )
устанавливает определённый флаг формата
(публичная функция-член std::ios_base )
сбрасывает определённый флаг формата
(публичная функция-член std::ios_base )
управляет точностью десятичных дробей в операциях с плавающей точкой
(публичная функция-член std::ios_base )
управляет шириной поля
(публичная функция-член std::ios_base )
Локали
устанавливает локаль
(публичная функция-член std::ios_base )
возвращает текущую локаль
(публичная функция-член std::ios_base )
Внутренний расширяемый массив
[static]
возвращает уникальное для программы целое число, безопасное для использования в качестве индекса для pword() и iword()
(публичная статическая функция-член std::ios_base )
изменяет размер приватного хранилища при необходимости и предоставляет доступ к элементу long по заданному индексу
(публичная функция-член std::ios_base )
изменяет размер приватного хранилища при необходимости и предоставляет доступ к элементу void * по заданному индексу
(публичная функция-член std::ios_base )
Прочее
регистрирует функцию обратного вызова событий
(публичная функция-член std::ios_base )
устанавливает, являются ли библиотеки ввода-вывода C++ и C совместимыми
(публичная статическая функция-член std::ios_base )
Классы-члены
исключение потока
(публичный класс-член std::ios_base )
инициализирует объекты стандартных потоков
(публичный класс-член std::ios_base )

Типы членов и константы

Тип Объяснение
тип режима открытия потока

Также определены следующие константы:

Константа Объяснение
app переход в конец потока перед каждой записью
binary открытие в бинарном режиме
in открытие для чтения
out открытие для записи
trunc удаление содержимого потока при открытии
ate переход в конец потока сразу после открытия
noreplace (C++23) открытие в эксклюзивном режиме

(typedef)
тип флагов форматирования

Также определены следующие константы:

Константа Объяснение
dec использование десятичной системы счисления для целочисленного ввода/вывода: см. std::dec
oct использование восьмеричной системы счисления для целочисленного ввода/вывода: см. std::oct
hex использование шестнадцатеричной системы счисления для целочисленного ввода/вывода: см. std::hex
basefield dec | oct | hex . Полезно для операций маскирования
left выравнивание по левому краю (добавляет символы заполнения справа): см. std::left
right выравнивание по правому краю (добавляет символы заполнения слева): см. std::right
internal внутреннее выравнивание (добавляет символы заполнения в указанную внутреннюю точку): см. std::internal
adjustfield left | right | internal . Полезно для операций маскирования
scientific генерация чисел с плавающей точкой в научной нотации, или шестнадцатеричной нотации при комбинации с fixed : см. std::scientific
fixed генерация чисел с плавающей точкой в фиксированной нотации, или шестнадцатеричной нотации при комбинации с scientific : см. std::fixed
floatfield scientific | fixed . Полезно для операций маскирования
boolalpha вставка и извлечение типа bool в буквенно-цифровом формате: см. std::boolalpha
showbase генерация префикса, указывающего систему счисления для целочисленного вывода, требование индикатора валюты в денежном вводе/выводе: см. std::showbase
showpoint безусловная генерация символа десятичной точки для вывода чисел с плавающей точкой: см. std::showpoint
showpos генерация символа + для неотрицательного числового вывода: см. std::showpos
skipws пропуск начальных пробельных символов перед определенными операциями ввода: см. std::skipws
unitbuf сброс вывода после каждой операции вывода: см. std::unitbuf
uppercase замена определенных строчных букв их эквивалентами в верхнем регистре в определенных операциях вывода: см. std::uppercase

(typedef)
тип состояния потока

Также определены следующие константы:

Константа Объяснение
goodbit нет ошибки
badbit неустранимая ошибка потока
failbit ошибка операции ввода/вывода (ошибка форматирования или извлечения)
eofbit достигнут конец файла в связанной входной последовательности

(typedef)
тип направления позиционирования

Также определены следующие константы:

Константа Объяснение
beg начало потока
end конец потока
cur текущая позиция указателя позиции потока

(typedef)
определяет тип события
(enum)
тип функции обратного вызова
(typedef)