Scroll to navigation

std::ios_base::failure(3) C++ Standard Libary std::ios_base::failure(3)

NAME

std::ios_base::failure - std::ios_base::failure

Synopsis


Defined in header <ios>
class failure;


The class std::ios_base::failure defines an exception object that is thrown on
failure by the functions in the Input/Output library.


std::ios_base::failure may be defined either as a member class of
std::ios_base or as a synonym (typedef) for another class with (since C++17)
equivalent functionality.


std-ios base-failure-2003-inheritance.svg
(until C++11)
Inheritance diagram
std-ios base-failure-inheritance.svg
(since C++11)
Inheritance diagram

Member functions


constructor constructs a new failure object with the given message
(public member function)
operator= replaces the failure object
(public member function)
what returns the explanatory string
(public member function)

std::ios_base::failure::failure


explicit failure( const std::string& message ); (until C++11)
explicit failure( const std::string& message,
const std::error_code& ec = (since C++11)
std::io_errc::stream );
explicit failure( const char* message, (1)
const std::error_code& ec = (2) (since C++11)
std::io_errc::stream );
failure( const failure& other ); (3) (until C++11)
failure( const failure& other ) noexcept; (since C++11)


1,2) Constructs the exception object using message as explanation string which can
later be retrieved using what().
ec is used to identify the specific reason for the failure.
(since C++11)
3) Copy constructor. Initialize the contents with those of other.
If *this and other both have dynamic type std::ios_base::failure then
std::strcmp(what(), other.what()) == 0.
(since C++11)

Parameters


message - explanatory string
ec - error code to identify the specific reason for the failure
other - another failure to copy

Notes


Because copying std::ios_base::failure is not permitted to throw exceptions, this
message is typically stored internally as a separately-allocated reference-counted
string. This is also why there is no constructor taking std::string&&: it would have
to copy the content anyway.

std::ios_base::failure::operator=


failure& operator=( const failure& other ); (until C++11)
failure& operator=( const failure& other ) noexcept; (since C++11)


Assigns the contents with those of other.
If *this and other both have dynamic type std::ios_base::failure then
std::strcmp(what(), other.what()) == 0 after assignment.
(since C++11)

Parameters


other - another exception object to assign with

Return value


*this

std::ios_base::failure::what


virtual const char* what() const throw(); (until C++11)
virtual const char* what() const noexcept; (since C++11)


Returns the explanatory string.

Parameters


(none)

Return value


Pointer to a null-terminated string with explanatory information. The string is
suitable for conversion and display as a std::wstring. The pointer is guaranteed to
be valid at least until the exception object from which it is obtained is destroyed,
or until a non-const member function (e.g. copy assignment operator) on the
exception object is called.

Notes


Implementations are allowed but not required to override what().

Inherited from std::system_error

Member functions


code returns error code
(public member function of std::system_error)
what returns an explanatory string
[virtual] (virtual public member function of std::system_error)

Inherited from std::runtime_error

Inherited from std::exception

Member functions


destructor destroys the exception object
[virtual] (virtual public member function of std::exception)
what returns an explanatory string
[virtual] (virtual public member function of std::exception)

Notes


Before the resolution of LWG issue 331, std::ios_base::failure declared a destructor
without throw(), where std::exception::~exception() was declared with throw()^[1].
This means the std::ios_base::failure::~failure() had a weaker exception
specification. The resolution is to remove that declaration so that the non-throwing
exception specification is kept.


LWG issue 363 targets the same defect and its resolution is to add throw() to the
declaraion of std::ios_base::failure::~failure(). That resolution was not applied
due to the confict between the two resolutions.


1. ↑ The non-throwing exception specification is now applied globally across the
standard library, so the destructors of standard library classes are not
declared with throw() or noexcept.

Example

// Run this code


#include <fstream>
#include <iostream>


int main()
{
std::ifstream f("doesn't exist");


try
{
f.exceptions(f.failbit);
}
catch (const std::ios_base::failure& e)
{
std::cout << "Caught an ios_base::failure.\n"
<< "Explanatory string: " << e.what() << '\n'
<< "Error code: " << e.code() << '\n';
}
}

Possible output:


Caught an ios_base::failure.
Explanatory string: ios_base::clear: unspecified iostream_category error
Error code: iostream:1


Defect reports


The following behavior-changing defect reports were applied retroactively to
previously published C++ standards.


DR Applied to Behavior as published Correct behavior
the constructor overload (1) initialized
LWG 48 C++98 the base class std::exception corresponding
with msg, but the base class does not have description removed
a matching constructor
LWG 331 C++98 std::ios_base::failure declared a removed the destructor
destructor without throw() declaration

See also


io_errc the IO stream error codes
(C++11) (enum)

2024.06.10 http://cppreference.com