扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
根据你提供的结果判断,你说的这个“11000011"数,不是二进制,是个十进制吧。
创新互联专业提供雅安机房托管服务,为用户提供五星数据中心、电信、双线接入解决方案,用户可自行在线购买雅安机房托管服务,并享受7*24小时金牌售后服务。
你把11000011化成二进制补码,然后右移两位。把结果再转换为十进制就是“2750002”了。
java中使用补码表示二进制,正数的补码是其本身,负数的补码是它的绝对值取反+1:
例如:
+3 二进制位0000 0011(最高位为符号位,0正,1负),补码为:0000 0011;
-3 绝对值二进制位0000 0011,求反为1111 1100,补码为1111 1101
对-32 ===== 1111 11012 结果为1111 1111(为补码) 化成十进制为-1;
可能说的不够详细,仅供参考。。。。
左移一位相当于乘以2,32 等于 2 的 5 次方,所以左移 5 位,即可算出 53 * 32 的值。代码如下:
public class App47 {
public static void main(String[] args) {
System.out.println(53 5);
System.out.println(53 * 32);
}
}
运算符 含义 示例
~ 按位非(NOT) b = ~a
按位与(AND) c = a b
| 按位或(OR) c = a | b
^ 按位异或(XOR) c = a ^ b
右移 b = a 2
右移,左边空出的位以0填充 b = a 2
左移 b = a 1
当然同样有 =,|=,^=,=,=,=。
有关这些操作的细节可以参看
位运算
前面介绍的各种运算都是以字节作为最基本位进行的。 但在很多系统程序中常要求在位(bit)一级进行运算或处理。C语言提供了位运算的功能, 这使得C语言也能像汇编语言一样用来编写系统程序。
一、位运算符C语言提供了六种位运算符:
按位与
| 按位或
^ 按位异或
~ 取反
左移
右移
1. 按位与运算 按位与运算符""是双目运算符。其功能是参与运算的两数各对应的二进位相与。只有对应的两个二进位均为1时,结果位才为1 ,否则为0。参与运算的数以补码方式出现。
例如:95可写算式如下: 00001001 (9的二进制补码)00000101 (5的二进制补码) 00000001 (1的二进制补码)可见95=1。
按位与运算通常用来对某些位清0或保留某些位。例如把a 的高八位清 0 , 保留低八位, 可作 a255 运算 ( 255 的二进制数为0000000011111111)。
main(){
int a=9,b=5,c;
c=ab;
printf("a=%d\nb=%d\nc=%d\n",a,b,c);
}
2. 按位或运算 按位或运算符“|”是双目运算符。其功能是参与运算的两数各对应的二进位相或。只要对应的二个二进位有一个为1时,结果位就为1。参与运算的两个数均以补码出现。
例如:9|5可写算式如下: 00001001|00000101
00001101 (十进制为13)可见9|5=13
main(){
int a=9,b=5,c;
c=a|b;
printf("a=%d\nb=%d\nc=%d\n",a,b,c);
}
3. 按位异或运算 按位异或运算符“^”是双目运算符。
Java代码:
public class test{ public static void main(String[] args) { String source = "cghjhgfgsdyugh"; int ch = source.charAt(0); for(int i=1; isource.length(); i++) { ch ^= source.charAt(i); } System.out.printf("%d : %c\n", ch, ch); }}
运行测试:
28 :
楼上是错的...
public class Test
{
public static void main(String[] args)
{
byte b=(byte)0xf1 ;
byte d=(byte)(b4);
System.out.println(d);
byte a=(byte)0xf1;
byte e=(byte)((a0xff)4);
System.out.println(e);
}
}
输出为
-1
15
解释如下:
问题1:
1.0xf1,这是直接书写的文字常量,java默认情况下表示int型,即0x000000f1
2.(byte)0xf1,是将int显示转化为byte,即强行截断取最低字节,即取0x000000f1的最低字节0xf1,所以得到的byte在内存里是0xf1,因为byte是有符号的,所以b是负数
3.位移会先将左边的数转化为int,再位移;负数扩展左边添1,所以0xf1扩展为0xfffffff1,添0右移4位结果是0x0fffffff
4.最后将int型的0x0fffffff显示转化为byte,即截断最低字节,得到0xff,即byte值的-1,所以输出为-1
问题2:
同理
1.(byte)0xf1是截断int值的最低字节得到0xf1,也是一个byte型负数
2.b0xff,左边是byte型,右边的文字常量默认是int型,所以左边的byte先为扩展为0xffffffff的int型,与右边的int值位与,所以b0xff的最终结果是int型的0x000000ff
3.将b0xff按符号位扩展右移4位,得到0x0000000f,最后截断最低字节得到byte值0x0f,所以e为0x0f,输出得到15
ok,就是这样
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流