- 首先建一个存放转换方法的类Changer。
- 写一个返回值类型为StringBuffer的方法ChangeHex来实现该功能。
- 使用一个循环来遍历整个输入的整数的二进制。因为计算机用32位来存储整数,每次循环将其与整数15(二进制:1111)相与,所以循环8次即可。
- 将相与的结果做判断,如过大于9则将其转为16进制对应的字母,如果小于10则不做处理。将该值存入StringBuffer类型的sb中。
- 然后向右移动该二进制数四位,获取16进制数的下一位的数。
- 因为该16进制数是倒着获取的,所以将该值调转一下在返回。
class Changer{
/*
将获取到的十进制整数转为十六进制
*/
public StringBuffer ChangeHex(int number){
StringBuffer sb = new StringBuffer();
for (int i=0; i<8; i++){
int temp = number&15;
if (temp > 9) {
sb.append((char) (temp - 10 + 'A'));
}else{
sb.append(temp);
}
number=number>>>4;
}
return sb.reverse();
}
}