Java-十进制转十六进制
2016-05-08 09:54
381 查看
思想:十进制转十六进制,只需要将十进制数num&15,然后num右移四位(num>>>4);这里使用查表法,即把‘0’-‘F’放在数组chs中,然后将chs[num&15]的值福遇到新的数组arr或容器StringBuffer中。查表法可对负数求相应的十六进制。
精髓:先“与”后“移”。class ToHex
{
public static void main(String[] args)
{
toHex_array(-60);//查表法可以针对负数求其十六进制。
//System.out.println("Hello World!");
}
//非查表法(最普通的方法)。重点在于
/*
temp=num&15;
if(temp>9)
sb.append((char)(temp-10+'A'));
else
sb.append(temp);
num=num>>>4;
*/
public static void toHex(int num){
StringBuffer sb=new StringBuffer();
int temp;
for(int i=0;i<8;i++){ //转成8位十六进制
temp=num&15;
if(temp>9)
sb.append((char)(temp-10+'A'));
else
sb.append(temp);
num=num>>>4;
}
System.out.print(sb.reverse());
}
/*
**********************下面两种方法都是用查表法进行实现数制转换的*****************************
*/
//用StringBuffer来存储
public static void toHex_table( int num){
char[] chs={'0','1','2','3','4',
'5','6','7','8','9',
'A','B','C','D','E',
'F'};//注意要从‘0’开始!!这样才能满足chs[1]='1'。
StringBuffer sb=new StringBuffer();
for(int i=0;i<8;i++){
int temp=num&15;
//System.out.print(chs[temp]);
sb.append(chs[temp]);
num=num>>>4;
}
System.out.print(sb.reverse());
}
//用数组来存储
public static void toHex_array( int num){
char[] chs={'0','1','2','3','4',
'5','6','7','8','9',
'A','B','C','D','E',
'F'};//注意要从‘0’开始!!这样才能满足chs[1]='1'。
char[] arr=new char[8];
int i=arr.length;
while(num!=0){
int temp=num&15;
arr[--i]=chs[temp];
num=num>>>4;
}
for(int j=i;j<arr.length;j++)
System.out.print(arr[j]);
}
}
精髓:先“与”后“移”。class ToHex
{
public static void main(String[] args)
{
toHex_array(-60);//查表法可以针对负数求其十六进制。
//System.out.println("Hello World!");
}
//非查表法(最普通的方法)。重点在于
/*
temp=num&15;
if(temp>9)
sb.append((char)(temp-10+'A'));
else
sb.append(temp);
num=num>>>4;
*/
public static void toHex(int num){
StringBuffer sb=new StringBuffer();
int temp;
for(int i=0;i<8;i++){ //转成8位十六进制
temp=num&15;
if(temp>9)
sb.append((char)(temp-10+'A'));
else
sb.append(temp);
num=num>>>4;
}
System.out.print(sb.reverse());
}
/*
**********************下面两种方法都是用查表法进行实现数制转换的*****************************
*/
//用StringBuffer来存储
public static void toHex_table( int num){
char[] chs={'0','1','2','3','4',
'5','6','7','8','9',
'A','B','C','D','E',
'F'};//注意要从‘0’开始!!这样才能满足chs[1]='1'。
StringBuffer sb=new StringBuffer();
for(int i=0;i<8;i++){
int temp=num&15;
//System.out.print(chs[temp]);
sb.append(chs[temp]);
num=num>>>4;
}
System.out.print(sb.reverse());
}
//用数组来存储
public static void toHex_array( int num){
char[] chs={'0','1','2','3','4',
'5','6','7','8','9',
'A','B','C','D','E',
'F'};//注意要从‘0’开始!!这样才能满足chs[1]='1'。
char[] arr=new char[8];
int i=arr.length;
while(num!=0){
int temp=num&15;
arr[--i]=chs[temp];
num=num>>>4;
}
for(int j=i;j<arr.length;j++)
System.out.print(arr[j]);
}
}
相关文章推荐
- java对世界各个时区(TimeZone)的通用转换处理方法(转载)
- java-注解annotation
- java-模拟tomcat服务器
- java-用HttpURLConnection发送Http请求.
- java-WEB中的监听器Lisener
- Android IPC进程间通讯机制
- Android Native 绘图方法
- Android java 与 javascript互访(相互调用)的方法例子
- 介绍一款信息管理系统的开源框架---jeecg
- 聚类算法之kmeans算法java版本
- java实现 PageRank算法
- PropertyChangeListener简单理解
- c++11 + SDL2 + ffmpeg +OpenAL + java = Android播放器
- 插入排序
- 冒泡排序
- 堆排序
- 快速排序
- 二叉查找树