最近看了一下学习资料,感觉进制转换其实还是挺有意思的,尤其是对于负数这一方面。

下面和大家分享一下,这里只写了十进制到二进制的转换,其实都是同样的道理

 1 public class Test1 {
 2 
 3     public static void main(String[] args) {
 4         toBin(-4);
 5         toBin(4);
 6     }
 7     /*
 8      * 函数名:toBin
 9      * 功能描述:用来将正数或者负数转换为二进制数
10      * 创建人:zx
11      * 返回值:void
12      * */
13     public static void toBin(int num){
14         //定义字符串,用来存放计算出来的二进制数据
15         StringBuffer sb=new StringBuffer();
16         while(num!=0){
17             //向字符串中添加计算出来的二进制数
18             //注:这里用到了&运算,不明白的读者,可以在网上查找一下
19             sb.append(num&1);
20             //对num进行无符号位运算,类似于除2运算,具体的区别还需要读者自己查找
21             num=num >>> 1;
22         }
23         //将字符串反序输出,
24         System.out.println(sb.reverse());
25     }
26 
27 }
View Code

相关文章:

  • 2022-12-23
  • 2022-12-23
  • 2021-12-29
  • 2022-12-23
  • 2021-12-17
  • 2022-01-05
  • 2021-12-20
猜你喜欢
  • 2021-11-30
  • 2021-12-27
  • 2022-02-17
  • 2022-01-23
  • 2022-01-16
  • 2021-10-31
  • 2021-06-09
相关资源
相似解决方案