std::shl
来自cppreference.com
| 在标头 <bit> 定义
|
||
| |
(C++29 起) | |
返回向负无穷方向舍入的 ⌊x · 2s
⌋,并截断以适配 T 类型。
参数
| x | - | 无符号整数类型的值 |
| s | - | 要移位的位数 |
返回值
截断至结果类型的 ⌊x · 2s
⌋。
注解
与 << 运算符不同,std::shl 永远不会导致未定义行为。
移位操作如同逐位向左移动 s 次;若 s 为负数,则如同逐位向右移动 -s 次,但需注意 -s 不会溢出。
| 功能特性测试宏 | 值 | 标准 | 功能特性 |
|---|---|---|---|
__cpp_lib_bitops |
202606L |
(C++20) | 更好的移位 |
可能的实现
template<class T, class S> // TODO: constraints
constexpr T shl(T x, S s) noexcept
{
constexpr auto width = S(std::numeric_limits<std::make_unsigned_t<T>>::digits);
if constexpr (std::is_signed_v<S>)
{
if (s < 0)
return s <= -width ? T(x < 0 ? -1 : 0) : x >> -s;
}
return s >= width ? T(0) : x << s;
}
|
示例
| 本节未完成 原因:暂无示例 |
参阅
(C++29) |
向右移位并避免未定义行为可能性 (函数模板) |
(C++20) |
计算逐位左旋转的结果 (函数模板) |
(C++20) |
计算逐位右旋转的结果 (函数模板) |