Deduktionshilfen für std::chrono::zoned_time
Von cppreference.com
< cpp | chrono | zoned time
| zoned_time() -> zoned_time<std::chrono::seconds>; |
(1) | (seit C++20) |
| template< class Duration > zoned_time( std::chrono::sys_time<Duration> ) |
(2) | (seit C++20) |
| template< class TimeZonePtrOrName > zoned_time( TimeZonePtrOrName&& ) -> zoned_time<std::chrono::seconds, /* siehe unten */>; |
(3) | (seit C++20) |
| template< class TimeZonePtrOrName, class Duration > zoned_time( TimeZonePtrOrName&&, std::chrono::sys_time<Duration> ) |
(4) | (seit C++20) |
| template< class TimeZonePtrOrName, class Duration > zoned_time( TimeZonePtrOrName&&, std::chrono::local_time<Duration>, |
(5) | (seit C++20) |
| template< class TimeZonePtrOrName, class Duration, class TimeZonePtr2 > zoned_time( TimeZonePtrOrName&&, std::chrono::zoned_time<Duration, TimeZonePtr2>, |
(6) | (seit C++20) |
Diese Deduktionshilfen normalisieren Duration auf eine minimale Auflösung von std::chrono::seconds und bieten eine korrekte Handhabung für Zeitzonennamen, die mit Typen angegeben werden, die in std::string_view konvertierbar sind.
3-6) Wenn std::is_convertible_v<TimeZonePtrOrName, std::string_view> true ist, ist das abgeleitete zweite Template-Argument const std::chrono::time_zone*. Andernfalls ist es std::remove_cvref_t<TimeZonePtrOrName>.