Namespaces
Variants

std:: swap (std::basic_ifstream)

From cppreference.net

template < class CharT, class Traits >
void swap ( basic_ifstream < CharT, Traits > & lhs, basic_ifstream < CharT, Traits > & rhs ) ;
**Примечание:** Весь представленный код находится внутри тегов ` `, которые относятся к тегам ` `/`
`, поэтому согласно инструкциям перевод не выполняется. HTML-разметка и C++ код сохранены в оригинальном виде.

Специализирует алгоритм std::swap для std:: basic_ifstream . Обменивает состояние lhs с состоянием rhs . Фактически вызывает lhs. swap ( rhs ) .

Содержание

Параметры

lhs, rhs - потоки, состояние которых нужно обменять

Возвращаемое значение

(нет)

Исключения

Может генерировать исключения, определяемые реализацией.

Пример

#include <fstream>
#include <iostream>
#include <string>
bool create_stream(std::ifstream& fs)
{
    try
    {
        std::string some_name = "/tmp/test_file.txt";
        std::ios_base::openmode some_flags = fs.trunc; // | other flags
        if (std::ifstream ts{some_name, some_flags}; ts.is_open())
        {
            std::swap(ts, fs); // stream objects are not copyable => swap
            return true;
        }
    {
    catch (...)
    {
        std::cout << "Exception!\n";
    }
    return false;
}
int main()
{
    if (std::ifstream fs; create_stream(fs))
    {
        // use fs stream
    }
}
**Примечания к переводу:** - HTML-теги, атрибуты и содержимое внутри ` `, `
` тегов сохранены без изменений
- C++ специфические термины (ifstream, swap, trunc, is_open и др.) не переводились
- Комментарии в коде сохранены на английском языке
- Переведен только текст интерфейса "Run this code" → "Запустить этот код"
- Сохранено оригинальное форматирование и структура HTML

Смотрите также

(C++11)
обменивает два файловых потока
(публичная функция-член)