std::chrono::year:: ok
|
|
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Member functions | ||||
|
year::ok
|
||||
| Nonmember functions | ||||
| Helper classes | ||||
|
(C++26)
|
|
constexpr
bool
ok
(
)
const
noexcept
;
|
(seit C++20) | |
Überprüft, ob der in
*
this
gespeicherte Jahreswert im gültigen Bereich liegt, d.h.
[
-
32767
,
32767
]
.
Rückgabewert
true
wenn der in
*
this
gespeicherte Jahreswert im Bereich
[
-
32767
,
32767
]
liegt. Andernfalls
false
.
Mögliche Implementierung
Sehen Sie die Implementierungen in libstdc++ , libc++ , und Howard Hinnants date.h .
class Year { short year_; // nur zur Darstellung public: bool ok() const noexcept { return year_ != std::numeric_limits<short>::min(); } /*...*/ }; |
Beispiel
#include <chrono> #include <iomanip> #include <iostream> int main() { std::cout << "input year │ internal value │ ok()\n" << std::boolalpha; for (const int i : {2020, 0x8000, 0x8001, 0xFFFF, 0x18000}) { const std::chrono::year y{i}; std::cout << std::setw(10) << i << " │ " << std::setw(14) << static_cast<int>(y) << " │ " << y.ok() << '\n'; } }
Mögliche Ausgabe:
input year │ internal value │ ok()
2020 │ 2020 │ true
32768 │ -32768 │ false
32769 │ -32767 │ true
65535 │ -1 │ true
98304 │ -32768 │ false