文章目录
前言
本人发布的一系列资料都是学习备份使用,以及方便日后复习,随着技术的不断提升,每个文章都会持续添加内容,或者是扩展文章,本是秉承着分享的心态,互相学习,互相提升,也希望提出更好的意见,以及学习思路,欢迎留言,欢迎评论,谢谢!!
什么是进制?
对于很多新手小白来说,学习过程中经常会听到“进制”这个词,但是进制是什么,又感觉自己懵懵的,今天我们就来科普一下 😃
数字电子电路中,逻辑门的实现直接应用了二进制,类似于我们日常生活中”开灯”与”关灯”的两个操作,通电灯亮,断电灯灭,因此现代的计算机和依赖计算机的设备里都用到二进制。两种状态的高电位与低电位对应表示成数字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对应的二进制数
- 简便算法: 11 先拆分成2的次幂元素组成的数, (8+2+1) 然后对应位置改成二进制 0000 1011
- 算式计算:不断除以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;
以上就是进制之间的转化啦~
进制转换快速查表
下表清晰的反应了不同数制之间的对应及转换关系: