进制 二进制 进制之间的转换

前言

本人发布的一系列资料都是学习备份使用,以及方便日后复习,随着技术的不断提升,每个文章都会持续添加内容,或者是扩展文章,本是秉承着分享的心态,互相学习,互相提升,也希望提出更好的意见,以及学习思路,欢迎留言,欢迎评论,谢谢!!

什么是进制?

对于很多新手小白来说,学习过程中经常会听到“进制”这个词,但是进制是什么,又感觉自己懵懵的,今天我们就来科普一下 😃

数字电子电路中,逻辑门的实现直接应用了二进制,类似于我们日常生活中”开灯”与”关灯”的两个操作,通电灯亮,断电灯灭,因此现代的计算机和依赖计算机的设备里都用到二进制。两种状态的高电位与低电位对应表示成数字1和0,每个数字称为一个比特(Bit,Binary digit的缩写)。一个 byte 表示 8 个比特(电位)。

比如,我们个人安装的光纤宽带如果是 100 兆宽带,但是为什么下载最高速度往往只能到十几兆,甚至更少呢?
这是因为采用的表示单位不同。100兆宽带指的是100兆bit,我们一般说下载速度指的是byte,那么100兆(bit)换算成byte需要除8,也就是 12.5 兆( byte)。

计算机内部表示任何数据都是用二进制。而与人进行交互时,就需要将二进制数据转换成人可以理解的内容,比如:10进制、文字、图片、音频视频等等。

所以进制也就是进位计数制,是人为定义的带进位的计数方法(有不带进位的计数方法,比如原始的结绳计数法,唱票时常用的“正”字计数法)。
在这里插入图片描述
对于任何一种进制—X进制,就表示每一位置上的数运算时都是逢X进一位。 十进制是逢十进一,十六进制是逢十六进一,二进制就是逢二进一,以此类推,x进制就是逢x进位。
我们常用的有以下几种进制:
Bin 二进制Binary,简写为B,在Java中的前缀表示为0b
Oct 八进制Octal,简写为O,在Java中的前缀表示为0
Des 十进制Decimal,简写为D
Hex 十六进制Hexadecimal,简写为H,在Java中的前缀表示为0x

还比如我们记录时间的60进制,比如60秒是一分钟,60分钟是一个小时

学到这里相信你已经了解什么是进制了,我们继续来认识一下二进制吧!

什么是二进制?

前言

对于任何一种进制—X进制,就表示每一位置上的数运算时都是逢X进一位。 十进制是逢十进一,十六进制是逢十六进一,二进制就是逢二进一,以此类推,x进制就是逢x进位。
我们常用的有以下几种进制:
Bin 二进制Binary,简写为B,在Java中的前缀表示为0b
Oct 八进制Octal,简写为O,在Java中的前缀表示为0
Des 十进制Decimal,简写为D
Hex 十六进制Hexadecimal,简写为H,在Java中的前缀表示为0x

初识二进制

其实,不同进制的计算方式是相通的:
我们先列一些常用的10进制与2进制的对应关系,大家先来感受一下:
在这里插入图片描述
通过这张图,有没有发现一些规律呢?
对于10进制而言:10到100需要乘以十进制的10,1000到10000也需要乘以10
对于2进制而言:每加一个0都需要乘以二进制的2,所以用2的指数来表示。
例如 10000000,1后面有7位,就可以用2的7次方表示。

我们列张图,大家来比较一下十进制乘10和二进制乘2的运算结果:
在这里插入图片描述

Java中的byte类型

java 中的 byte 类型整数是单字节类型,也就是说,它使用 8 位(bit) 来表示整数。

8 位(bit)能表示的数字
在这里插入图片描述
但是!!!java中byte类型的左侧的一位规定用来表示符号,0表示正数,1表示负数。那么它表示数字的位就只有7位,而不是8位,所以:

java 中 byte 类型正数的表示:
在这里插入图片描述
java 中 byte 类型负数的表示:
java 的 byte 类型如何表示负数?最小值-128.符号位是1,其余7位是0,得10000000
那-128+1得-127,表示为10000001,那么可以以此类推,继续执行加1运算加到负数的最大值:11111111,如下图所示:
在这里插入图片描述

Java中整数类型的最小值与最大值

与 byte 类型相同,short,int 和 long 也是用相同的方式表示整数。
这四种类型的最小值和最大值分别可以这样表示:

4.1 byte(1字节,8位):

2进制 2的指数
最小 10000000 -2^7
最大 01111111 2^7 - 1

4.2 short(2字节,16位)

2进制 2的指数
最小 10000000 00000000 -2^15
最大 01111111 11111111 2^15 - 1

4.3 int(4字节,32位):

2进制 2的指数
最小 10000000 00000000 00000000 00000000 -2^31
最大 01111111 11111111 11111111 11111111 2^31 - 1

4.4 long(8字节,64位):

2进制 2的指数
最小 10000000 00000000 00000000 00000000 00000000 00000000 00000000 00000000 -2^63
最大 01111111 11111111 11111111 11111111 11111111 11111111 11111111 11111111 2^63 - 1

进制之间的转换

前言

进制也就是进位计数制,是人为定义的带进位的计数方法,类似于统计”正”字,对于任何一种进制,X进制,就表示每一位置上的数运算时都是逢X进一

10进制 : 逢十进一,包含元素 0~9
16进制 : 逢十六进一,包含元素 0~9 a b c d e f
2 进制 : 逢二进一,包含 0 和 1

通常情况下: 1byte = 8个二进制位
表示一个数字如果用二进制来表示的话,可以写成: 0000 1111
把这8个位进行组合,每3位组合就形成了8进制
每4位组合就形成了16进制

不同进制的特点

2进制 : 逢二进一 , 包含 0和1 , 以0b开头

8进制 : 逢八进一 , 包含 0~7 , 以0开头

10进制 : 逢十进一 , 包含元素 0~9

16进制 : 逢十六进一 ,包含元素 0~9 a b c d e f ,以0x开头

进制之间的转换

关于二进制的一些数据
在这里插入图片描述

二进制转十进制

需求:计算二进制数据:0000 1101 对应的十进制
在这里插入图片描述

十进制转二进制

需求:求十进制数字11对应的二进制数

  1. 简便算法: 11 先拆分成2的次幂元素组成的数, (8+2+1) 然后对应位置改成二进制 0000 1011
  2. 算式计算:不断除以2商0为止,取余,倒着写,11的结果:1011
    7的结果0111(读的时候先朝右,再朝上的方向读)
    在这里插入图片描述

二进制转八进制

从低次位开始,每3位为一组,产生一个八进制数字,最高位不足补0
需求:计算二进制数据110 0111对应的八进制
在这里插入图片描述
需求:计算八进制数据023 0653对应的二进制数据
在这里插入图片描述

十六进制转二进制

一个数字拆分成4个数字
举例:b->11对应的二进制数1011

二进制转十六进制

四个一组,转为一个数字,以0x开始
举例: 1111->15 ,a在16进制代表的是10,依次类推,15对应的16进制数就是f

代码实现二进制与十进制互转

java 中也提供了二进制和十进制的互转方法

十进制转二进制

 private static void desToBin() {//10进制转2进制
        String s = Integer.toBinaryString(257);
        System.out.println(s);//100000001
 }

二进制转十进制

Integer.parseInt(String s, int radix)
第一个参数:要转成十进制数的二进制字符串
第二个参数:指定的进制
注意:这里不支持直接使用负数的二进制码来表示负数,而是要用正数的二进制码添加负号来表示

    private static void binToDes() {
        int i = Integer.parseInt("-1100101101", 2);
        System.out.println(i);//813
        int i2 = Integer.parseInt("-1100101101", 2);
        System.out.println(i2);//-813
    }

练习

需求:输入十进制整数转成2进制,输入二进制整数转成十进制

package cn.cxy.exec;

import java.util.Scanner;

/*完成十进制与二进制之间的转换*/
public class Test {
    public static void main(String[] args) {
        //m1();
        m2();
    }

    private static void m2() {
        while (true) {
            System.out.print("输入整数的二进制码:");
            String s = new Scanner(System.in).nextLine();
            int a = Integer.parseInt(s, 2);
            System.out.println("对应的十进制数是:"+a);
        }
    }

    private static void m1() {
        while (true) {
            System.out.print("输入十进制整数:");
            int a = new Scanner(System.in).nextInt();
            String s = Integer.toBinaryString(a);
            System.out.println("对应的二进制数是:"+s);
        }
    }
}

二进制数据在Java代码中的写法

在Java语法中:二进制字面值可以使用 0b 前缀的整数直接表示:
int a = 0b11001;
byte b = 0b1111111;
// 0b前缀语法不允许直接写负数的二进制码,这样写实际表示的是正数128
byte c = 0b10000000; //此处错误

// 要写byte的最小值-128,需要写 128 的二进制码,并加负号
byte d = -0b10000000;

以上就是进制之间的转化啦~

进制转换快速查表

下表清晰的反应了不同数制之间的对应及转换关系:
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值