| 
 
| 10进制转其他进制方法有几种,最好可以编写出通用的方法,只需要通过参数的形式调用即可。 方法一:利用StringBuffer,对于16进制需要进行是否 大于9的判断,大于9需要转化成对应的字母表示,通过(char)(temp - 10 + 'A')
 
 方法二:查表法。转化的数字通过数组来存储。复制代码class ArrayTest5 
{
        public static void main(String[] args) 
        {
                toHex(60);
        }
        
        /*
           十进制-->十六进制,利用到StringBuffer。
        */
        public static void toHex(int num)
        {
                StringBuffer sb = new StringBuffer();
                for(int x=0; x<8; x++)
                {
                        // 取低四位的值,15的二进制为0000 0000 0000 0000 0000 0000 0000 1111
                        int temp = num & 15;
                        // 如果大于9,对应相应的字母
                        if(temp>9)
                                sb.append((char)(temp-10+'A'));
                        else
                                // 把低四位的转化值添加到StringBuffer中
                                sb.append(temp);
            //无符号右移4位
                        num  = num >>> 4;
                }
                // 反转输出结果
                System.out.println(sb.reverse());
        }
        /*
            十进制-->二进制
        */
        public static void toBin(int num)
        {
                StringBuffer sb = new StringBuffer();
                while(num>0)
                {
                        sb.append(num%2);
                        num = num / 2;
                }
                System.out.println(sb.reverse());
        }
}
 方法三:通用方法,通过参数传递决定转化进制。复制代码class ArrayTest6 
{
        public static void main(String[] args) 
        {
            //toHex(60);
                toBin(-6);
        }
        /*
                十进制转化为二进制
        */
        public static void toBin(int num)
        {
                //定义二进制的表。
                char[] chs = {'0','1'};
                //定义一个临时存储容器。
                char[] arr = new char[32];
                //定义一个操作数组的指针
                int pos = arr.length;
                while(num!=0)
                {
                        int temp = num & 1;
                        arr[--pos] = chs[temp];
                        num = num >>> 1;
                }
                for(int x=pos; x<arr.length; x++)
                {
                        System.out.print(arr[x]);
                }
        }
        /*
                0 1 2 3 4 5 6 7 8 9 A  B  C   D  E  F  ==十六进制中的元素。
                0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
                查表法:将所有的元素临时存储起来,建立对应关系。
                每一次&15后的值作为索引去查建立好的表,就可以找对应的元素。
                这样比 -10+'a'简单的多。
                这个表怎么建立呢?
                可以通过数据的形式来定义。
                终于出结果了,但是是反着的,想要正过来可以通过StringBuffer reverse功能来完成,
                也可以使用已经学习过的容器:数组来完成存储。
        */
        public static void toHex(int num)
        {
                char[] chs = {'0','1','2','3'
                                        ,'4','5','6','7'
                                        ,'8','9','A','B'
                                        ,'C','D','E','F'};
                
                //定义一个临时容器。
                char[] arr = new char[8];
                int pos = arr.length;
                while(num!=0)
                {
                        int temp = num & 15;
                        
                        arr[--pos] = chs[temp];        
                        num = num >>> 4;
                }
                System.out.println("pos="+pos);
                //存储数据的arr数组遍历。
                for(int x=pos;x<arr.length; x++)
                {
                        System.out.print(arr[x]+",");
                }
        }
}
 复制代码class ArrayTest7 
{
        public static void main(String[] args) 
        {
                  toBin(-6);
                //toHex(-60);
                //toOctal(60);
        //System.out.println(Integer.toBinaryString(6));
             System.out.println(Integer.toHexString(6));
        }
        /*
                十进制-->二进制
        */
        public static void toBin(int num)
        {
                trans(num,1,1);
        }
        /*
                十进制-->八进制
        */
        public static void toOctal(int num)
        {
                trans(num,7,3);
        }
        /*
                十进制-->十六进制
        */
        public static void toHex(int num)
        {
                trans(num,15,4);
        }
    //通用的转换方法,传递的参数分别为:待转化数字、与运算的对应值、无符号右移的偏移量。
        //注意:这里的方法直接输出了转化后的值,返回值为void,而实际使用时大多需要范围值,范围值类型为String
        public static void trans(int num,int base,int offset)
        {
                //如果带转化数字为0,直接输出0
                if(num==0)
                {
                        System.out.println(0);
                        return ;
                }
                char[] chs = {'0','1','2','3'
                                        ,'4','5','6','7'
                                        ,'8','9','A','B'
                                        ,'C','D','E','F'};
                char[] arr = new char[32];
                int pos = arr.length;
                while(num!=0)
                {
                        int temp = num & base;
                        arr[--pos] = chs[temp];
                        num = num >>> offset;
                }
                for(int x=pos; x<arr.length; x++)
                {
                        System.out.print(arr[x]);
                }
                return ;
        }
}
 
 
 
 
 | 
 |