std::chrono:: is_am, std::chrono:: is_pm, std::chrono:: make12, std::chrono:: make24
From cppreference.net
|
定义于头文件
<chrono>
|
||
|
constexpr
bool
is_am
(
const
std::
chrono
::
hours
&
h
)
noexcept
;
|
(1) | (C++20 起) |
|
constexpr
bool
is_pm
(
const
std::
chrono
::
hours
&
h
)
noexcept
;
|
(2) | (C++20 起) |
|
constexpr
std::
chrono
::
hours
make12
(
const
std::
chrono
::
hours
&
h
)
noexcept
;
|
(3) | (C++20 起) |
|
constexpr
std::
chrono
::
hours
make24
(
const
std::
chrono
::
hours
&
h,
bool is_pm ) noexcept ; |
(4) | (C++20 起) |
这些函数有助于在12小时制时间格式与24小时制时间格式之间进行转换。
1)
检测24小时制时间是否为上午(
ante meridiem
,中午之前)。
2)
检测24小时制时间是否为下午时段(
post meridiem
,正午之后)。
3)
返回24小时制时间的12小时制等效值。
4)
返回12小时制时间
h
对应的24小时制等效值,其中
is_pm
用于确定该时间是否为下午时段。
参数
| h | - | 待检测的12小时制或24小时制时间 |
| is_pm | - | 12小时制时间是否为下午时段 |
返回值
1)
0h
<=
h
&&
h
<=
11h
2)
12h
<=
h
&&
h
<=
23h
3)
若
h
在区间
[
0h
,
23h
]
内,则返回对应的12小时制数值,范围在
[
1h
,
12h
]
之间。否则,返回值是未指定的。
4)
若
h
在区间
[
1h
,
12h
]
内,当
is_pm
为
false
时返回对应24小时制区间
[
0h
,
11h
]
的值,否则返回区间
[
12h
,
23h
]
的值。其他情况下返回值未指定。
示例
运行此代码
#include <chrono> #include <iomanip> #include <iostream> #include <utility> int main() { using namespace std::chrono; static_assert( is_am(10h) && is_am(11h) && !is_am(12h) && !is_am(23h) && !is_pm(10h) && !is_pm(11h) && is_pm(12h) && is_pm(23h) ); std::cout << "make12():\n"; for (const hours hh : {0h, 1h, 11h, 12h, 13h, 23h}) { const hours am{make12(hh)}; std::cout << std::setw(2) << hh.count() << "h == " << std::setw(2) << am.count() << (is_am(hh) ? "h a.m.\n" : "h p.m.\n"); } std::cout << "\nmake24():\n"; using p = std::pair<hours, bool>; for (const auto& [hh, pm] : {p{1h, 0}, p{12h, 0}, p{1h, 1}, p{12h, 1}}) { std::cout << std::setw(2) << hh.count() << (pm ? "h p.m." : "h a.m.") << " == " << std::setw(2) << make24(hh, pm).count() << "h\n"; } }
输出:
make12(): 0h == 12h a.m. 1h == 1h a.m. 11h == 11h a.m. 12h == 12h p.m. 13h == 1h p.m. 23h == 11h p.m. make24(): 1h a.m. == 1h 12h a.m. == 0h 1h p.m. == 13h 12h p.m. == 12h