龙空技术网

快速掌握左移<<、右移>>位运算及使用技巧

锦鲤与梨 74

前言:

此刻大家对“c语言右移怎么补1”大概比较重视,我们都需要剖析一些“c语言右移怎么补1”的相关资讯。那么小编在网上汇集了一些有关“c语言右移怎么补1””的相关知识,希望各位老铁们能喜欢,小伙伴们一起来学习一下吧!

左移<<运算

将二进制数向左移位操作,高位溢出则丢弃,低位补0

a=11;a<<1;移位前:0000 1011移位后:0001 0110(十进制值为22)

b=5;b<<2;移位前:0000 0101移位后:0001 0100(十进制值为20)

根据上述样例我们可以发现,对一个数左移1位就是乘以2,左移n位就是乘以2的n次方(而左移运算比乘法快得多)

右移>>运算

右移位运算中,无符号数和有符号数的运算并不相同。对于无符号数,右移之后高位补0;对于有符号数,符号位一起移动,正数高位补0,负数高位补1

无符号数a=16;a>>3;移位前:0001 0000移位后:0000 0010(十进制值为2)

有符号数(正数)b=32;a>>3;移位前:0010 0000移位后:0000 0100(十进制值位4)

有符号数(负数)b=-32;b>>3;移位前:1010 0000移位后:1000 0100(十进制值为-4)

c=25;c>>4;移位前:0001 1001移位后:0000 0001(十进制值为1)

实际上,我们发现。右移n位就是除以2的n次方,当得到的商不是整数时会往小取整

标签: #c语言右移怎么补1 #整数左移的算法 #整数右移 #整数右移前面补什么