左移一位相等乘2,左移两位相当于乘以4,依次类推。
右移一位相当于除以2,右移两位相当于除以4,依次类推。
测试代码如下:
static void Main(string[] args)
{
//8,16,32
uint lines = 0;
uint bit = 1;
for (int i = 0; i < 32; i++)
{
bit = bit << 1;
Console.WriteLine($"执行{i+1}次左移位:{bit } --->{Convert.ToString(bit, 2)}");
}
Console.ReadLine();
bool[] RelayIsOn = new bool[8] { true, false, true, false, false, false, true, true };
for (int i = 0; i < RelayIsOn.Length; i++)
{
if (RelayIsOn[i])
{
lines = lines | bit;
//Console.WriteLine(lines);
}
else
{
//do not thing
}
bit = bit << 1;
Console.WriteLine($"{bit} ---{Convert.ToString(bit, 2)}");
Console.WriteLine($"{lines} --->{Convert.ToString(lines, 2)}");
}
}
输出:
执行1次左移位:2 —>10
执行2次左移位:4 —>100
执行3次左移位:8 —>1000
执行4次左移位:16 —>10000
执行5次左移位:32 —>100000
执行6次左移位:64 —>1000000
执行7次左移位:128 —>10000000
执行8次左移位:256 —>100000000
执行9次左移位:512 —>1000000000
执行10次左移位:1024 —>10000000000
执行11次左移位:2048 —>100000000000
执行12次左移位:4096 —>1000000000000
执行13次左移位:8192 —>10000000000000
执行14次左移位:16384 —>100000000000000
执行15次左移位:32768 —>1000000000000000
执行16次左移位:65536 —>10000000000000000
执行17次左移位:131072 —>100000000000000000
执行18次左移位:262144 —>1000000000000000000
执行19次左移位:524288 —>10000000000000000000
执行20次左移位:1048576 —>100000000000000000000
执行21次左移位:2097152 —>1000000000000000000000
执行22次左移位:4194304 —>10000000000000000000000
执行23次左移位:8388608 —>100000000000000000000000
执行24次左移位:16777216 —>1000000000000000000000000
执行25次左移位:33554432 —>10000000000000000000000000
执行26次左移位:67108864 —>100000000000000000000000000
执行27次左移位:134217728 —>1000000000000000000000000000
执行28次左移位:268435456 —>10000000000000000000000000000
执行29次左移位:536870912 —>100000000000000000000000000000
执行30次左移位:1073741824 —>1000000000000000000000000000000
执行31次左移位:2147483648 —>10000000000000000000000000000000
执行32次左移位:0 —>0
整型长度32位,左移32位后直接溢出。