std::chrono::nonexistent_local_time
| Определено в заголовочном файле <chrono>
|
||
class nonexistent_local_time; |
(начиная с C++20) | |
Определяет тип объекта, который выдаётся как исключение, чтобы сообщить, что была предпринята попытка преобразовать несуществующий std::chrono::local_time в std::chrono::sys_time без указания std::chrono::choose (например, choose::earliest или choose::latest).
Это исключение генерируется std::chrono::time_zone::to_sys и вызывающими её функциями (например, конструкторами std::chrono::zoned_time, которые принимают std::chrono::local_time).
Диаграмма наследования
Содержание
Функции-элементы
(конструктор) |
создаёт объект исключения (public функция-элемент) |
operator= |
заменяет объект исключения (public функция-элемент) |
what |
возвращает пояснительную строку (public функция-элемент) |
std::chrono::nonexistent_local_time::nonexistent_local_time
<tbody> </tbody> template< class Duration > nonexistent_local_time( const std::chrono::local_time<Duration>& tp, const std::chrono::local_info& i ); |
(1) | (начиная с C++20) |
nonexistent_local_time( const nonexistent_local_time& other ) noexcept; |
(2) | (начиная с C++20) |
Создаёт объект исключения.
what(), эквивалентна строке, создаваемой os.str() после следующего кода:std::ostringstream os;
os << tp << " находится в промежутке между\n"
<< std::chrono::local_seconds(i.first.end.time_since_epoch()) + i.first.offset
<< ' ' << i.first.abbrev << " и\n"
<< std::chrono::local_seconds(i.second.begin.time_since_epoch()) + i.second.offset
<< ' ' << i.second.abbrev
<< " которые оба эквивалентны\n"
<< i.first.end << " UTC";
i.result != std::chrono::local_info::nonexistent.*this и other имеют динамический тип std::chrono::nonexistent_local_time, тогда std::strcmp(what(), other.what()) == 0.Параметры
| tp | — | момент времени, для которого была предпринята попытка преобразования |
| i | — | std::chrono::local_info, описывающий результат попытки преобразования |
| other | — | другой nonexistent_local_time для копирования
|
Исключения
Может сгенерировать std::bad_alloc
Примечание
Поскольку при копировании класса стандартной библиотеки, производного от std::exception, не разрешается создавать исключения, это сообщение обычно хранится внутри в виде отдельно выделенной строки с подсчётом ссылок.
std::chrono::nonexistent_locale_time::operator=
<tbody> </tbody> nonexistent_locale_time& operator=( const nonexistent_locale_time& other ) noexcept; |
(начиная с C++20) | |
Присваивает содержимое содержимому other. Если *this и other имеют динамический тип std::chrono::nonexistent_locale_time, тогда std::strcmp(what(), other.what()) == 0 после присваивания.
Параметры
| other | — | другой объект исключения для присваивания |
Возвращаемое значение
*this
std::chrono::nonexistent_locale_time::what
<tbody> </tbody> virtual const char* what() const noexcept; |
(начиная с C++20) | |
Возвращает пояснительную строку.
Параметры
(нет)
Возвращаемое значение
Указатель на завершающуюся нулём строку с пояснительной информацией. Строка подходит для преобразования и отображения в виде std::wstring. Указатель гарантированно действителен, по крайней мере, до тех пор, пока объект исключения, из которого он получен, не будет уничтожен или пока не будет вызвана неконстантная функция-элемент (например, оператор присваивания копированием) для объекта исключения.
Примечание
Реализации могут, но не обязаны переопределять what().
Унаследован от std::runtime_error
Унаследован от std::exception
Функции-элементы
[virtual] |
уничтожает объект исключения (virtual public of std::exception функция-элемент)
|
[virtual] |
возвращает поясняющую строку (virtual public of std::exception функция-элемент)
|
Смотрите также
(C++20) |
исключение, сообщающее, что местное время неоднозначно (класс) |