byte & 0xff char 转换
https://blog.csdn.net/lixingtao0520/article/details/75450883
版权声明:本文为博主原创文章,转载请注明作者与出处,http://blog.csdn.net/lixingtao0520 https://blog.csdn.net/lixingtao0520/article/details/75450883
在Java中 byte型数据在内存中占8位,int型数据在内存中占32位。0xff默认为int型,是十六进制,十进制中表示为255,二进制为32位,后八位为'1111 1111',其他24位均为0;在&运算时,2个bit均为1,则得1,否则得0。
先看以下程序
byte a = -17;
System.out.println(a);
System.out.println((int) a);
System.out.println(a & 0xff);
System.out.println(Integer.toBinaryString((int) a));
System.out.println(Integer.toBinaryString(a & 0xff));
运行程序输出以下结果:

说明:
1、a是byte型时,二进制表示为11101111;即-17(byte型);
2、a在强制转化为int型时,值仍为-17,转换规则:如果是负数,则高位补1,如果是正数,则高位补0。所以,a的值仍为-17(int型),二进制表示形式为'11111111111111111111111111101111'。
3、a & 0xff 操作时,因为a为byte型,所以会将a自动转化为int型(高位补1),再与0xff进行&操作,返回的数值二进制表示为'00000000000000000000000011101111'(toBinaryString方法省略了左边的0),此数值为239(int型)。
4、byte & 0xff操作一般将byte数据转换成int型,最终的数据只有低8位有数据,其他位为0。
5、Java中byte型转换为int型有两种:一种是保持数值不变,例如进行数值计算时,此时可采用强制类型转换,int b = (int) a ;另外一种是最低字节中各个位不变,高位用0填充,此时需要采用位操作 int b = a & 0xff,例如在编解码时,以及BufferedInputStream中的read方法。
public synchronized int read() throws IOException {
if (pos >= count) {
fill();
if (pos >= count)
return -1;
}
return getBufIfOpen()[pos++] & 0xff;
}
---------------------
作者:BiggerLee
来源:CSDN
原文:https://blog.csdn.net/lixingtao0520/article/details/75450883
版权声明:本文为博主原创文章,转载请附上博文链接!
https://blog.csdn.net/iblade/article/details/73289831
在MD5运算中 通常会把MD5(十六进制的byte[])转成HexString,
会用到一个方法 private static String bytesToHex1(byte[] md5Array) {
StringBuilder strBuilder = new StringBuilder();
for (int i = ; i < md5Array.length; i++) {
int temp = 0xff & md5Array[i];//TODO:此处为什么添加 0xff & ?
String hexString = Integer.toHexString(temp);
if (hexString.length() == ) {//如果是十六进制的0f,默认只显示f,此时要补上0
strBuilder.append("").append(hexString);
} else {
strBuilder.append(hexString);
}
}
return strBuilder.toString();
} 又如此段代码: byte[] bs = digest.digest(origin.getBytes(Charset.forName(charsetName))) ; for (int i = ; i < bs.length; i++) {
int c = bs[i] & 0xFF ;
if(c < ){
sb.append("");
}
sb.append(Integer.toHexString(c)) ;
}
return sb.toString() ; 反复出现byte & 0xff 到底在做什么? 举个简单的例子: byte[] b = new byte[]; b[] = -; byte 8位二进制 = 1个字节 char 2个字节 short (2个字节) int(4个字节) long(8个字节) float (4个字节) double(8个字节) 计算机存储数据机制:正数存储的二进制原码,负数存储的是二进制的补码。 补码是负数的绝对值反码加1。 比如-,- 的绝对值原码是: 取反: 加1: byte –> int 就是由8位变 位 高24位全部补1: ; 0xFF 是计算机十六进制的表示: 0x就是代表十六进制,A B C D E F 分别代表10 F就是15 一个F 代表4位二进制:可以看做 是 。 0xFF的二进制表示就是: 。 高24位补0: ; -12的补码与0xFF 进行与(&)操作 最后就是0000 转换为十进制就是 。 byte类型的数字要&0xff再赋值给int类型,其本质原因就是想保持二进制补码的一致性。 当byte要转化为int的时候,高的24位必然会补1,这样,其二进制补码其实已经不一致了,&0xff可以将高的24位置为0,低8位保持原样。这样做的目的就是为了保证二进制数据的一致性。 有人问为什么上面的式子中b[]不是8位而是32位,因为当系统检测到byte可能会转化成int或者说byte与int类型进行运算的时候,就会将byte的内存空间高位补1(也就是按符号位补位)扩充到32位,再参与运算。
---------------------
作者:iblade
来源:CSDN
原文:https://blog.csdn.net/iblade/article/details/73289831
版权声明:本文为博主原创文章,转载请附上博文链接!
https://blog.csdn.net/u011080472/article/details/51280919
https://blog.csdn.net/zhaominpro/article/details/79602381
https://blog.csdn.net/xiaozhouchou/article/details/79086604
public static void main(String[] args) {
int i = 1;
int k = 0;
for(int j = 0;j<33;j++){
i = i << 1;
System.out.println(Integer.toBinaryString( i));
System.out.println(i);
}
System.out.println(i);
}
2
100
4
1000
8
10000
16
100000
32
1000000
64
10000000
128
100000000
256
1000000000
512
10000000000
1024
100000000000
2048
1000000000000
4096
10000000000000
8192
100000000000000
16384
1000000000000000
32768
10000000000000000
65536
100000000000000000
131072
1000000000000000000
262144
10000000000000000000
524288
100000000000000000000
1048576
1000000000000000000000
2097152
10000000000000000000000
4194304
100000000000000000000000
8388608
1000000000000000000000000
16777216
10000000000000000000000000
33554432
100000000000000000000000000
67108864
1000000000000000000000000000
134217728
10000000000000000000000000000
268435456
100000000000000000000000000000
536870912
1000000000000000000000000000000
1073741824
10000000000000000000000000000000
-2147483648
0
0
0
0
byte & 0xff char 转换的更多相关文章
- java乱码详解(java中byte与char的转换)
转自:http://hi.baidu.com/%C6%F3%D2%B5%BC%D2%D4%B0/blog/item/825a4858d6248e8b810a181a.html java byte与 ...
- C# byte 和 char 转化
C# byte 和 char 可以认为是等价的.但是在文本显示的时候有差异. c# 使用的是unicode字符集,应该和为ascii相互转换 只能转换到字符的unicode编码,或者由unico ...
- Java 中byte 与 char 的相互转换 Java基础 但是很重要
char转化为byte: public static byte[] charToByte(char c) { byte[] b = new byte[2]; b[0] = ...
- java中String byte HexString的转换
原文:http://blog.sina.com.cn/s/blog_62e9ec530101ebv6.html HexString——>byte public static byte[] hex ...
- C# byte[]与char[]、string与char[]、byte[] 与 string 互转
1. byte array -> char array Byte[] b=new byte[5]{0x01,0x02,0x03,0x04,0x05}; Char[] c=Encoding.AS ...
- Java数据类型之byte、char
Java 有8中基本数据类型,分别是byte.int.long.char.float.double.boolean. 1.byte.char的简单介绍 有时候总是搞不清byte.char,所以就现在好 ...
- visual studio中如何将string类型值转为BYTE(unsigned char)类型
昨天困惑一件事,就是手里有个string类型的字符串,像01 23 45 67 89 AB CD EF,根据空格拆分为一个个的子字符串后(如EF),需要放到一个BYTE(typedef unsigne ...
- 转载 Golang []byte与string转换的一个误区
Golang []byte与string转换的一个误区 https://www.oyohyee.com/post/Note/golang_byte_to_string/ 2019-08-10 23:4 ...
- C# Stream 和 byte[] 之间的转换
一. 二进制转换成图片 MemoryStream ms = new MemoryStream(bytes); ms.Position = ; Image img = Image.FromStream( ...
随机推荐
- InnoDB启用大内存页
在 Linux 操作系统上运行内存需求量较大的应用程序时,由于其采用的默认页面大小为 4KB,因而将会产生较多 TLB Miss 和缺页中断,从而大大影响应用程序的性能.当操作系统以 2MB 甚至更大 ...
- Github上Laravel开源排行榜Star数31-60名
Github上Laravel开源排行榜Star数31-60名,罗列所有 Laravel 开源扩展包,含 Github Star 数量,下载数量和项目简介.默认排序是按Star数量从多到少来排 31.c ...
- 20170811 JQuery基础知识学习记录(一)
基本写法 $(selector).action() $(this).hide() - 隐藏当前元素 $("p").hide() - 隐藏所有 <p> 元素 $(&quo ...
- 20165236郭金涛 预备作业3 Linux安装及学习
我在Linux安装过程遇到的问题: 1.“不能为虚拟电脑XX打开一个新任务”: 出现这种情况是电脑没有开启blos,解决方法是:开机进入联想界面的时候,直接按F2可以快速进入选择开启blos. Lin ...
- java poi生成excel(个人例子js-jsp-java)
js代码: function exportRepQudl(){ if(confirm("导出输出页面内容?")){ var id = $("input[name='id' ...
- MySQL深入理解
[存储引擎] InnoDB表引擎 默认事务型引擎,最重要最广泛的存储引擎,性能非常优秀. 数据存储在共享表空间,可以通过配置分开. 对主键查询的性能高于其他类型的存储引擎. 内部做了很多优化,从磁盘读 ...
- IOP知识点(2)
1 URL资源访问不足时,需要添加URL权限 2 重定向问题解决办法:3 cloud-service-factory 项目 gradlew方法 1 URL资源访问不足时,需要添加URL权 ...
- Tx.Origin 用作身份验证
Solidity 中有一个全局变量,tx.origin,它遍历整个调用栈并返回最初发送调用(或交易)的帐户的地址.在智能合约中使用此变量进行身份验证会使合约容易受到类似网络钓鱼的攻击. 有关进一步阅读 ...
- Go vs Erlang - 转
From http://zhang.hu/go-vs-erlang/ Go vs Erlang 因为 云巴 系统对高并发.低延迟的需求,我们对各个语言.平台做了很多的调研比较工作.这自然就包括致力于开 ...
- Kotlin Linux下的环境搭建
Kotlin是JVM世界里的未来主宰,不管你信不信,我反正相信了! 好吧,如果你不糊涂,就跟着我一起学学吧,哈哈 一下载https://github.com/JetBrains/kotlin/rele ...