当前位置: 首页>>代码示例 >>用法及示例精选 >>正文


Swift UInt16 &>>=(_:_:)用法及代码示例


用法一

操作符

&>>=(_:_:)

计算将值的二进制表示向右移动指定位数的结果,将移位量屏蔽为类型的位宽,并将结果存储在左侧变量中。

声明

static func &>>= <Other>(lhs: inout Self, rhs: Other) where Other : BinaryInteger

参数

lhs

要转移的值。

rhs

向右移动 lhs 的位数。如果 rhs 超出范围 0..<lhs.bitWidth ,则会对其进行屏蔽以生成该范围内的值。

详述

&>>= 运算符执行 masking shift ,其中作为 rhs 传递的值被屏蔽以产生 0..<lhs.bitWidth 范围内的值。使用此屏蔽值执行移位。

以下示例将 x 定义为 UInt8 的一个实例,这是一个 8 位无符号整数类型。如果在对 x 的操作中使用 2 作为右侧值,则移位量不需要屏蔽。


var x: UInt8 = 30                 // 0b00011110
x &>>= 2
// x == 7                         // 0b00000111

但是,如果您将 19 用作 rhs ,则操作首先将 rhs 位掩码到 3 ,然后使用该掩码值作为要移位的位数 lhs


var y: UInt8 = 30                 // 0b00011110
y &>>= 19
// y == 3                         // 0b00000011

可用版本

iOS 8.0+, iPadOS 8.0+, macOS 10.10+, Mac Catalyst 13.0+, tvOS 9.0+, watchOS 2.0+

用法二

操作符

&>>=(_:_:)

计算将值的二进制表示向右移动指定位数的结果,将移位量屏蔽为类型的位宽,并将结果存储在左侧变量中。

声明

static func &>>= (lhs: inout UInt16, rhs: UInt16)

参数

lhs

要转移的值。

rhs

向右移动 lhs 的位数。如果 rhs 超出范围 0..<lhs.bitWidth ,则会对其进行屏蔽以生成该范围内的值。

详述

&>>= 运算符执行 masking shift ,其中作为 rhs 传递的值被屏蔽以产生 0..<lhs.bitWidth 范围内的值。使用此屏蔽值执行移位。

以下示例将 x 定义为 UInt8 的一个实例,这是一个 8 位无符号整数类型。如果在对 x 的操作中使用 2 作为右侧值,则移位量不需要屏蔽。


var x: UInt8 = 30                 // 0b00011110
x &>>= 2
// x == 7                         // 0b00000111

但是,如果您将 19 用作 rhs ,则操作首先将 rhs 位掩码到 3 ,然后使用该掩码值作为要移位的位数 lhs


var y: UInt8 = 30                 // 0b00011110
y &>>= 19
// y == 3                         // 0b00000011

可用版本

iOS 8.0+, iPadOS 8.0+, macOS 10.10+, Mac Catalyst 13.0+, tvOS 9.0+, watchOS 2.0+

相关用法


注:本文由纯净天空筛选整理自apple.com大神的英文原创作品 UInt16 &>>=(_:_:)。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。