左移操作会将一个数的二进制表示向左移动一定数量的位数,并在右侧添加零。如果左移后的结果大于数据类型所能表示的最大值,就会发生溢出。对于无符号数,左移操作不会导致溢出问题。但对于带符号数,由于左移操作可能会改变符号位,因此需要考虑是否应该在左移时导致溢出。
对于左移操作是否应该导致溢出,存在两种不同的处理方式: 符号扩展和截断。
int x = -8; // 有符号数,x是二进制补码表示 int y = x << 2; // 左移2位,使用符号位扩展 // y的值为-32,即补码 111000
int x = -8; // 有符号数,x是二进制补码表示 int y = x << 2; // 左移2位,使用截断 // y的值为-32,即补码 11100000
选择如何处理左移