toSigned 抽象方法

int toSigned(
  1. int width
)

返回这个整数最不稳定的 width 位,将最高保留位扩展到符号位。这与使用具有符号位 2 的补码表示法将值截断以适应 width 位相同。返回的值在最高 width 位的所有位置上具有相同的位值。

                         //     V--sign bit-V
16.toSigned(5) == -16;   //  00010000 -> 11110000
239.toSigned(5) == 15;   //  11101111 -> 00001111
                         //     ^           ^

此操作可以用于模拟来自底层语言的算术。例如,要增加一个 8 位带符号的数量

q = (q + 1).toSigned(8);

q 将从 0 计数到 127,回绕到 -128 并计数回到 127

如果输入值可以适应 width 位而无需截断,则结果与输入相同。避免截断 x 所需要的最小宽度是 x.bitLength + 1,即

x == x.toSigned(x.bitLength + 1);

实现

int toSigned(int width);