服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Java教程 - Java 3种方法实现进制转换

Java 3种方法实现进制转换

2020-09-26 21:37鄙人剑人肖 Java教程

这篇文章主要介绍了Java 3种方法实现进制转换,帮助大家利用Java处理数据,感兴趣的朋友可以了解下

由其他进制转换为十进制比较简单,下面着重谈一谈十进制如何化为其他进制。

1.使用Java带有的方法Integer,最简单粗暴了,代码如下

?
1
2
3
4
5
6
7
8
9
10
11
12
13
//使用java提供的方法
  //但仅局限于比较常用的二进制、八进制、十六进制
  public static String trans1(int num, int radix)
  {
    if(radix == 2)
      return Integer.toBinaryString(num);
    else if(radix == 8)
      return Integer.toOctalString(num);
    else if(radix == 16)
      return Integer.toHexString(num);
 
    return null;
  }

2.使用数组进行交换,贴码:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
//使用数组的形式进行转换
  public static void trans2(int num, int radix)
  {
    System.out.println(num+"转成"+radix+"进制数为:");
 
    //创建数组,32位
    char[] arr = new char[32];
 
    //创建参考字符数组
    char[] ch = {
      '0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'
    };
 
    //指针,从数组最后开始
    int pos = 32;
 
    //开始循环计算num和radix的商和余数
    while(num > 0)
    {
      arr[--pos] = ch[num % radix];
      num /= radix;
 
      /*
       * 这里是针对二进制、八进制和十六进制进行的移位运算
      arr[--pos] = ch[num&(radix-1)];
      if(radix == 2)
        num >>= 1;
      else if(radix == 8)
        num >>= 3;
      else if(radix == 16)
        num >>= 4;
      */
    }
 
    //输出有效的进制数
    for(int i = pos; i < 32; i++)
      System.out.print(arr[i]);
 
    System.out.println();
  }

3.使用StringBuilder类型,贴码:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
//使用StringBuilder进行转换
  public static String trans3(int num, int radix)
  {
    //使用StringBuilder的reverse方法
    StringBuilder sb = new StringBuilder();
 
    while(num > 0)
    {
      //把除以基数的余数存到缓冲区中
      sb.append(num % radix);
      num /= radix;
    }
 
    return sb.reverse().toString();
  }

以上就是Java 3种方法实现进制转换的详细内容,更多关于Java 进制转换的资料请关注服务器之家其它相关文章!

原文链接:https://www.cnblogs.com/xiaolongdejia/archive/2004/01/13/10867121.html

延伸 · 阅读

精彩推荐