Пространства имён
Варианты
Действия

std::chrono::nonexistent_local_time

Материал из cppreference.com
< cpp‎ | chrono
 
 
Библиотека утилит
Языковая поддержка
Поддержка типов (базовые типы, RTTI)
Макросы тестирования функциональности библиотеки (C++20)    
Управление динамической памятью
Программные утилиты
Поддержка сопрограмм (C++20)
Вариативные функции
Трёхстороннее сравнение (C++20)
(C++20)
(C++20)(C++20)(C++20)(C++20)(C++20)(C++20)
Общие утилиты
Дата и время
Функциональные объекты
Библиотека форматирования (C++20)
(C++11)
Операторы отношения (устарело в C++20)
Целочисленные функции сравнения
(C++20)(C++20)(C++20)    
(C++20)
Операции обмена и типа
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
Общие лексические типы
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
Элементарные преобразования строк
(C++17)
(C++17)
 
 
Определено в заголовочном файле <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).

cpp/error/exceptioncpp/error/runtime errorstd-chrono-nonexistent local time-inheritance.svg

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

Содержание

[править] Функции-элементы

(конструктор)
создаёт объект исключения
(public функция-элемент)
operator=
заменяет объект исключения
(public функция-элемент)
what
возвращает пояснительную строку
(public функция-элемент)

std::chrono::nonexistent_local_time::nonexistent_local_time

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)

Создаёт объект исключения.

1) Пояснительная строка, возвращаемая 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.
2) Конструктор копирования. Если *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=

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

virtual const char* what() const noexcept;
(начиная с C++20)

Возвращает пояснительную строку.

Параметры

(нет)

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

Указатель на завершающуюся нулём строку с пояснительной информацией. Строка подходит для преобразования и отображения в виде std::wstring. Указатель гарантированно действителен, по крайней мере, до тех пор, пока объект исключения, из которого он получен, не будет уничтожен или пока не будет вызвана неконстантная функция-элемент (например, оператор присваивания копированием) для объекта исключения.

Примечание

Реализации могут, но не обязаны переопределять what().

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


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

Функции-элементы

уничтожает объект исключения
(virtual public of std::exception функция-элемент) [править]
[virtual]
возвращает поясняющую строку
(virtual public of std::exception функция-элемент) [править]

[править] Смотрите также

исключение, сообщающее, что местное время неоднозначно
(класс) [править]