十六进制的元素个数固定,而且还有对应编号,可以用查表法.一个int类型十进制数在32位操作系统中占4个字节,32位2进制数取它的低8位,例如60,在内存中以二进制数0011 1100存放,而一个十六进制数中每一位数对应二进制中4位数,因此可以将十进制数与F进行“与(&)”运算,得出低四位(十六进制中的最低位),然后左移4位继续与F与运算,得出十六进制数的所有位数,然后存在一个数组中,存储的是它从最低位到最高位的所有数,由于顺序是逆的,因此输出时应该去零逆置加上前缀0x输出。
class ArraytoHex {
public static void main(String[] args) {
int num = 60;
String str_hex = toHex(num);
System.out.println(str_hex);
}
/*
* 需求:十进制转十六进制 思路:十六进制的元素个数固定,而且还有对应编号,可以用查表法.一个int类型
* 十进制数在32位操作系统中占4个字节,32位2进制数取它的低8位,例如60,在内存 中以二进制数0011
* 1100存放,而一个十六进制数中每一位数对应二进制中4位数, 因此可以将十进制数与F进行“与(&)”运算,得出低四位(十六进制中的最低位),
* 然后左移4位继续与F与运算,得出十六进制数的所有位数,然后存在一个数组中,去零逆置输出
*/
public static String toHex(int num) {
// 1.建表
char[] chs = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F' };
// 2.创建存储十六进制数的低8位数的临时容器
char[] arr = new char[8];
// 3.创建操作容器中十六进制数每一位数的下标
int index = arr.length;
// 4.通过循环对num进行&F,>>>4的操作
while (num != 0) {
// 5.对num进行&运算得十六进制数最低位数
int temp = num & 15;
// 6.根据&运算后的结果,作为下标,查表获取对应的字符,将它存储在临时容器中
arr[--index] = chs[temp];
// 7.对num进行右移,求次低位数
num = num >>> 4;
}
// 8.调用方法,将数组转换成字符串输出
return "0x" + toString(arr, index);
}
// 9.定义一个方法,将数组转换成字符串
public static String toString(char[] arr, int index) {
String temp = "";
for (int x = index; x < arr.length; x++) {
temp = temp + arr[x];
}
return temp;
}
}