本文目录一览:
java 位移运算
首先要执行移位操作。。必须将byte转换成int。。。
bt的二进制表示为1000 0001
转换成int后二进制表示为 11111111 11111111 11111111 1000 0001
先执行b3,右移三位变为:11111111 11111111 11111111 1111 0000
再执行b3,左移三位变为: 1111111 11111111 11111111 1000 0000
bt 是byte类型。。所以再截断。。。取1000 0000
第一位是符号位,1表示负数。。。所以结果就是-128(2的七次方)
同样的分析方法。。。。
先表示成int的二进制反码表示方式。。。
11111111 11111111 11111111 1101 0000
右移三位变成:1111111 1111111 1111111 1111 1010
左移三位变成:11111111 11111111 11111111 1101 0000
截断变成 1101 000
这个反码表示就是-48
希望能帮到你~!
java如何用移位符将一个数字加32?
只通过位移符无法得到结果,因为位移符向左每位移一位相当于乘以2,向左位移5位相当于乘以2×2×2×2×2=32,所以十进制数字1向左位移5为可以得到1×32=32。其本质是十进制数的1转换为二进制数后为0000 0001,其向左位移5位后为0010 0000,转换为十进制数就是32。
位移相当于乘法,所以我们无法只通过位移符使一个数加32,那么就这样吧:
运行结果:
1 5 = 32,所以1 + 1 5 = 33, 2 + 1 5 = 34, 3 + 1 5 = 35。
java位移运算符有什么意义
给你举个例子,乘除法可以使用位运算,速度更快。很多底层的东西是用位运算去实现的,你去看看java的很多源码,还有IO流的处理有时候会用位运算,二进制文件的读写解析等都需要位运算,如果你了解底层的东西,你会位运算,这回让你的程序生涯更加精彩,望采纳,谢谢
java位移问题
移位操作:
左移:向左移位,符号后面的数字是移了多少位,移的位用0补齐,例如2进制数01111111左移一位后变为11111110,移位是字节操作。
右移:向右移位,符号后面的数字是移了多少位,移的位用符号位补齐,例如01111111右移一位后变为00111111,而10000000右移一位后变成11000000,因为符号位是1。
你的例题num用2进制表示为1111 1111 1111 1111 1111 1111 1110,向左移了4次位就变成1111 1111 1111 1111 1111 1110 0000。十分简单
奖励就不用了。
0x代表16进制,0xFFFFFFE就是一个十六进制的数,化成2进制的数就是:
1111 1111 1111 1111 1111 1111 1110,这个数太大了,化成十进制就是:16的7次方减2。
移位都是在2进制下做的操作,硬件的实现也很简单,向左移其实就是把每一个2进制位都向左移1位,这样不就像10进制的数乘了个十么。比如11左移一位就是110,但是本来存这个数的内存只有两位,现在多了一位,那就舍呗,于是就变成10了。你这个数大,但是道理是一样的。
右移稍复杂点,还举个简单的例子,11向右移一位,11还可以看成啥呢,就是011.0,于是右移一位就是,01.10,舍掉小数不就是01了。但是这是错的,就是符号位的问题,计算机死规定最高位是符号位,也又做了一个死规定,就是11不能看成011.0,11前面的位必须看成和符号位一样的数,也就是看成111.0,那右移一位不就是11.10,舍去小数就变成11了,如果是01,就看成001.0,右移一位就变成00.10,于是就是00。关键是符号位,也就是最高位,最高位是1,右移就把最高位补1,如果最高位是0,右移就把最高位补0。死规定,就得记。
右移就是这点麻烦,左移挺简单。
你这个数最高位是1,所以右移就补1,但是你给的例子是左移的(箭头指的方向),所以不用想那么多,移了4位就是这么个样子,不用再多说了吧,应该理解了,要还不懂就说哪不懂。
抱歉哦,马虎了,int型变量是4字节,所以0xffffffe由于不到4字节,所以前面用0补齐,也就是0x0ffffffe,这是4个字节.
左移1位一次:0x1fffffffc
左移1位两次:0x3fffffff8
左移1位三次:0x7fffffff0
左移1位四次:0xfffffffe0
这样就没问题了。
java int怎么位移取前几位数字?
思路:直接用Integer类的bit运算操作。
如果想得到一个n位数的第k位,写法如下:
(n ( 1 k )) k
内部实现就是:
1、创建一个mask,把1左移k位
int mask = 1 k;
2、然后把n右移mask位就是想要得到的结果
int masked_n = n mask;
int thebit = masked_n k。
class Tester{
public static void main (String[] args) {
String str = "2013年6月12日,XXXXXXXXXXXXX";
String reg = "([^,,]+)[,,].*$";
String r = str.replaceAll(reg, "$1");
reg = "^((\\d+)年)?((\\d+)月)?((\\d+)日)?$";
String sy = r.replaceAll(reg,"$2");
String sm = r.replaceAll(reg,"$4");
String sd = r.replaceAll(reg,"$6");
int y, m, d;
try {
y = Integer.parseInt(sy);
} catch(Exception e) {
y = 0;
}
try {
m = Integer.parseInt(sm);
} catch(Exception e) {
m = 0;
}
try {
d = Integer.parseInt(sd);
} catch(Exception e) {
d = 0;
}
System.out.format("%d, %d, %d", y, m, d);
}
}