java 字节转为16进制字符的个人理解
来源:互联网 发布:java分割符 编辑:程序博客网 时间:2024/06/10 17:27
public static void printHexString(byte[] b) {for (int i = 0; i < b.length; i++) {int temp = b[i] & 0xFF;String hex = Integer.toHexString(temp);if (hex.length() == 1) {hex = '0' + hex;}System.out.print(hex.toUpperCase());}}
以上代码将字节转为十六进制字符,以下是个人理解:
0.上面思路是:byte转int再算出16进制字符;
1.一个字节需要二进制的8个位,一个整型需要二进制的32个位;
2. 十六进制的1位相当于二进制的4个位;
3. java的二进制是补码(第一位是符号,相对于原码,后面的位全部取反后+1);
4. 在二进制里,对于正数,原码,反码,补码表示都一样,但是,对于负数,原码,反码,补码表示各不同;
5. 不论是byte还是int,我们debug时看到的数值都是我们最常用的十进制数值;
上面是理论基础,下面是理解重点:
6. 对于负数,当byte直接转为int时,在二进制里,8位扩为32位,会进行补位,补位的结果是:数值没变,但是转换成十六进制字符变了(2个十六进制位变成了8个)。
举例(注意第三点):十进制的-1,二进制8个位表示:11111111; 补位后,二进制32个位表示:11111111111111111111111111111111,数值没变,都是十进制的-1,但是换成16进制的位表示,就有:0xFF变为0xFFFFFFFF,出现了差错;
7.负数进行byte & 0xFF 运算后的整型, 结合第一点,假设byte的十进制数值是-1,在二进制里运算是11111111111111111111111111111111 & 00000000000000000000000011111111 ,运算方法是单个位进行与运算,得到结果是00000000000000000000000011111111,即把byte的高24位清零,留下低8位,结果是:byte的十进制数值被改变,但是转换成十六进制有0xFF------>0xFF,消除了差错;
8.十六进制字符长度为1时补零:byte转为16进制应该有16进制的两个位,当16进制数值<=9时进行补位
如以上理解有误,欢迎指正!
- java 字节转为16进制字符的个人理解
- java 字节流的个人理解
- 字节流与字符流、字节与字符 --个人理解
- 理解Java中字符流与字节流的区别
- Java 字节流与字符流的总结和理解
- 理解Java中字符流与字节流的区别
- 理解java中字符流与字节流的区别
- 理解Java中字符流与字节流的区别
- 理解Java中字符流与字节流的区别
- 理解Java中字符流与字节流的区别
- java IO,字符字节终极理解
- C语言中16进制字符串转为字节流的实现
- JAVA中关于IO流中的字符流和字节流的个人总结
- 比特,字节,字符概念的理解
- 一个字符的ACSII码转为16进制的形式
- 流 java 流 字符流 字节 流的学习与理解
- 字符串逆序,字符串转为字符数组 、字符串转字节数组,字节数组转字符串、java中String、StringBuffer、StringBuilder
- 黑马程序员 对字节流的个人理解
- KeyGenerator加解密在windows和linux的同步
- 将nodejs-express配置成全局可用状态
- Spring Boot+Mybatis动态数据源配置
- Qt中父子widget的事件传递
- java String类的字符串常量不可变更
- java 字节转为16进制字符的个人理解
- 传输层协议之传输控制协议(TCP)总结
- 10 Minutes to pandas
- ssh更改端口
- 矩阵旋转
- 单例模式C++
- Android面试相关
- JVM重要知识点整理和学习
- vs 2013 添加xunit测试