Namespaces
Variants

std::basic_ofstream<CharT,Traits>:: open

From cppreference.net

void open ( const char * filename,

std:: ios_base :: openmode mode

= std:: ios_base :: out ) ;
(1)
void open ( const std :: filesystem :: path :: value_type * filename,

std:: ios_base :: openmode mode

= std:: ios_base :: out ) ;
(2) (начиная с C++17)
(3) (начиная с C++11)
(4) (начиная с C++17)

Открывает и связывает файл с именем filename с файловым потоком.

При успехе вызывает clear ( ) . При неудаче вызывает setstate ( failbit ) .

1,2) Эффективно вызывает rdbuf ( ) - > open ( filename, mode | ios_base :: out ) (см. std::basic_filebuf::open для подробностей о эффектах этого вызова). Перегрузка (2) предоставляется только если std::filesystem::path::value_type не является char . (since C++17)
3,4) Эффективно вызывает (1,2) как если бы с помощью open ( filename. c_str ( ) , mode ) .

Содержание

Параметры

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

Пример

Отчеты о дефектах

Следующие отчеты об изменениях поведения, влияющие на дефекты, были применены ретроактивно к ранее опубликованным стандартам C++.

DR Applied to Behavior as published Correct behavior
LWG 22 C++98 it was unclear how error state changes upon a successful open the error state is unchanged
LWG 409 C++98 the error state was unchanged upon a successful open it is cleared [1]
  1. Решение проблемы LWG #22 переопределено.

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

проверяет, есть ли у потока связанный файл
(публичная функция-член)
закрывает связанный файл
(публичная функция-член)
открывает файл и настраивает его как связанную символьную последовательность
(публичная функция-член std::basic_filebuf<CharT,Traits> )