---恢复内容开始---

进制

在一般生活中,我们一直在应用的十进制,就是逢十进一,而今天我们要接触的是,计算机编程常用的进制!首先我们要知道,计算机内部运算采用的是二进制,也就是逢二进制!

1.什么是二进制?

就是只有0 和 1  每当遇到值为2 就向前进一位。

2.为什么计算机内部是二进制?

这就要从硬件说起,计算机是如何储存数据的,要知道我们网络传输,就是你要和别人一起聊天,你们隔着很远,到底是怎样才能让他收到你的聊天内容? 有一根网线还能说过去,毕竟网线链接终端我们也不知道连到哪,保不齐就是全世界都是用网线链接。但是无线的时候为什么还是可以聊天内容又是怎么算的?

附:我们网路传输主要是更具我们电脑从应用层到物理层硬件设备,物理层将数据链路层数据帧转换为传输介质相应的信号形式,如光信号、电磁波信号等然后由路由器通讯,只要不是同一个网络,我们传输都要依靠路由。在这样说就扯远了,简单地说,我们计算机为什么要用二进制,到底和上面的有什么关系?正是因为我们用的的是电和光传播数据,那么在硬件设备要识别这些电和光传输的是什么是很麻烦的,比如给他弄个什么形状是代表什么,这太复杂而且传输太不稳定一开始就被淘汰这种想法,到后来那些大神们就规定 波长呈升型表示1 波长呈降型就表示0 平行表示不变,因为就只有这两种形态,所以使用二进制最合适,所以计算机内部是二进制!

注意:在我们JAVA教程一般讲的是我们计算机传输电信号开就是1 关就是0这是一种形象的说法。毕竟我们了解二进制而他具体是怎么实现计数的没多大必须性。

那么就来简单模拟一下JAVA教程最常让我们理解的一种方式

看图片 ,通电状态标识1 不同电表示0.

综上所述,你只要简单明白:这是由计算机的工作原理决定的,计算机进行运算实际是靠的电路,电路的逻辑只有0和1两个状态,这里的0和1并不是数字的0和1,0和1是表示两种不同的状态,0表示低电平,1表示高电平。因为计算机是由无数个逻辑电路组成的,只能根据0和1的无限位数和组合来表达信息。所以二进制是最接近计算机工作模式的,也是计算机直接能读懂的,其他高级语言都需要转义成机器语言。

我们要学习的不是计算机怎么去采集电信号和光信号,而是知道计算机常用的进制:1.十进制 2.二进制 3.八进制 4十六进制

1.十进制逢十进一位 也就是 1 2 3 4 5 6 7 8 9  到了十 怎么表示的 就是10 他就进了以为

2.二进制逢二进一位 也就是 0 1 到了2的时候 他也仅为 10 在二进制这个表示2不是10哦

3.八进制逢八进一位 也就是 0 1 2 3 4 5 6 7 到了8的时候,他就进一位 10 表示 十进制的8

4.十六进制逢十六进制 也就是 0 1 2 3 4 5 6 7 8 9 A(10) B(11) C(12) D(13) E(14) F(15) 6不6 数字不够,字母凑。

知道这些进制有什么用,不知道你有没有这个疑问?为什么要学习它?

目前在我们后面要学会数据类型和位运算都是需要进制的知识,具体是进制哪方面的知识呢?就是即将要讲的 进制转换!

进制转换:就是这些进制之间的互相转化,计算机内部计算是二进制,那么到底我们打开系统的计算机,他是什么原理,让我们可以进行十进制运算?是怎么做到的,这个是今天的主要针对内容!

看不懂八进制和十六进制没关系,先尝试去理解意思,其他具体数字转换得值可以忽略,等看了十进制转二进制再回头来看一遍!

首先我们要知道的是八进制:

八进制的特点是逢八进一位。那么来看下面这一段二进制数:0111     打开计算机,选择程序员类型。(不会选自己百度)

BIN:二进制  HEX:十六进制  OCT:八进制 DEC:十进制!

没错这个数字表示7。

在哪我们在看一个二进制数:1000

注意看:OCT写的是不是 10  是不是向前进了一位?

所以八进制我们用二进制一般这样去转换   三个二进制位表示八进制的一位!

十六进制同理,我就不用计算机了,直接给你写出来

二进制转十六进制:

因为二进制1111 表是的就是15  而十六进制是16进一,所以二进制转十六进制是 四个二进制位表示十六进制一位。

那么明白了这点,我们来做几个练习题:

00010001  计算出他的十六进制和八进制

二进制:  000010001

八进制: 000 010 001

最终答案:0    2      1     所以是:21

卧槽,怎么搞的这个数难道是21 我怎么用计算机计算出的21并不是这个答案,于是开始慌了!

这是一个用对进制不熟悉造成的,注意我们求得是二进制对八进制,我们别看DEC这个是十进制。如果你和我一样是WIN10首先要去点击OCT然后在看BIN是多少

没毛病吧! 然后我们通过这个转换还明白了一个点记住:进制不会我们就用计算机转呗,反正又不是常用,算法能记就记,记不住我们就用计算机,实在想找算法就百度呗!

好了八进制是没毛病了,我们再看十六进制例子:

BIN:00010001

HEX:0001  0001

转换:11

明吧了吧,就是把二进制转分割然后分别计算出他们的值,这样能达到快速转换!

十进制转二进制:

   看了上面的转换估计有一个疑问  0001你怎么就知道是1 ? 这不乱讲么,我都不知道为什么0001是 1额。别急,学了十进制转二进制,不管多少进制你瞬间就能明白了!

  首先学十进制转二进制 我们用最原始的表达式来学习:十进制转二进制就是一直用十进制除以2,出尽后最后是1则最后一位是1 如果出尽最后一位则是0,从下往上排列!注意这个原始算法对于十六进制和八进制都是通用的,最主要的是八进制和十六进制,要分割 比如十六进制 2F 两位数,要知道一位十六进制表示的是  0000 四个个二进制位 所以 分别用来除以2 然后按照位置前后组合得到的0和1  八进制也是同理,八进制是三个位,就这里和十六进制不同,按三个位分!

         例:我们现在要将10转换为2进制

解析:就是一直除以2 在第一次10/2=5 没有余数,所以此位置就是0  然后在得的数5 再除以2  5/2=2%1 所以此位置是1  得到2,此时2/2=1 所以最终答案:1010

此时我们在做两个例子

将十进制25转换成二进制数:

             2 | 25        1
------
2 | 12 0
------
2 | 6 0
----
2 | 3 1
------
1 从下往上排列就是二进制数:11001

那么学了十进制,那么十进制转二进制怎么算呢?整数二进制用数值乘以2的幂次依次相加,小数二进制用数值乘以2的负幂次然后依次相加!

举个例子: 0101 转 十进制

这就是进制转换,如果你是新手,来看我资料,估计我这个资料有点针对我个人写的,那么我给你找几个文章学习进制转换:

http://jingyan.baidu.com/article/495ba84109665338b30ede98.html

http://www.cnblogs.com/syqlp/p/6586995.html

http://blog.csdn.net/xy2204/article/details/50522075

二进制快速转十进制方法:

以8位 来演示:

1.第一种:

00000001      1

00000010      2

00000100      4

00001000      8

00010000      16

00100000      32

01000000      64

10000000      128

2.第二种:

00000001      1

00000011      3

00000111      7

00001111      15

00011111      31

00111111      63

01111111      127

3.第三种:

10000000     128

11000000     192

11100000     224

11110000     240

11111000     248

11111100     252

11111110     254

举个例子:  11101011

可分为:

11100000(上面第三种类型)   224

00001000(上面第一种类型)   8

00000011(上面第二种类型)   3

我们通过记住上面三种类型的转换,再用加 法(加法口算你会吧)立即得到结果:235

==================================================================================

方法二:

熟记以下排列,其实很Easy了,从右往 左,依次是前一个数的2倍:

256      128      64       32      16      8        4         2         1

随便写个数字比如48

48 = 32 + 16,所以在32 和 16所在的位置为1,其余为0,

转为2进制就是

256  128  64  32  16  8   4   2   1

0      0       0    1    1   0   0   0   0

二进制转十进制就更简单了,

比如随便写的一串 01111101

先写上 :  0         1           1         1         1         1          0          1

然后填充 128      64        32       16        8          4          2          1

十进制为 64+32+16+8+4+1=125

 

看不懂只能自己去看视频,这边听边讲的好学会,用文字这个样给你说,你本来没点基础,我是没法让你看懂的!

---恢复内容结束---

Java基础笔记(3) 进制与进制转换的更多相关文章

  1. Java基础笔记 – Annotation注解的介绍和使用 自定义注解

    Java基础笔记 – Annotation注解的介绍和使用 自定义注解 本文由arthinking发表于5年前 | Java基础 | 评论数 7 |  被围观 25,969 views+ 1.Anno ...

  2. 【转】Java基础笔记 – 枚举类型的使用介绍和静态导入--不错

    原文网址:http://www.itzhai.com/java-based-notes-introduction-and-use-of-an-enumeration-type-static-impor ...

  3. 黑马程序员----java基础笔记上(毕向东)

    ------Java培训.Android培训.iOS培训..Net培训.期待与您交流! ------- 笔记一共记录了毕向东的java基础的25天课程,分上.中.下 本片为上篇,涵盖前10天课程 1. ...

  4. JAVA基础笔记15-16-17-18

    十五.今日内容介绍 1.Object 2.String 3.StringBuilder =第一节课开始======================= 01API概念 * A:API(Applicati ...

  5. 黑马程序员----java基础笔记中(毕向东)

    <p>------<a href="http://www.itheima.com" target="blank">Java培训.Andr ...

  6. Java基础笔记1

    java (开源,跨操作系统)j2ee jre java基础 javaoop java高级 JDK(JAVA developer Kitool): java开发工具 (开发人员使用) JRE(java ...

  7. Java基础笔记(一)——JDK、JRE、JVM

    JDK.JRE和JVM三者的关系 Java程序执行过程 JVM(java virtual machine) 注:由于各种操作系统(windows.linux等)支持的指令集(二进制可执行代码)不同,程 ...

  8. Java基础笔记05-06-07-08

    五.今日内容介绍 1.方法基础知识 2.方法高级内容 3.方法案例 01方法的概述 * A: 为什么要有方法 * 提高代码的复用性 * B: 什么是方法 * 完成特定功能的代码块. 02方法的定义格式 ...

  9. Java基础笔记(六)——进制表示、ASCII码和Unicode编码

    Java中有三种表示整数的方法:十进制.八进制.十六进制. 八进制:以0开头,包括0~7的数字.如:int octal=020;  //定义int型变量存放八进制数据 十六进制:以0x或0X开头,包括 ...

随机推荐

  1. 【LeetCode】200. 岛屿的个数

    题目 给定一个由 '1'(陆地)和 '0'(水)组成的的二维网格,计算岛屿的数量.一个岛被水包围,并且它是通过水平方向或垂直方向上相邻的陆地连接而成的.你可以假设网格的四个边均被水包围. 示例 1:输 ...

  2. [原创]Base32加密解密工具

    工具: Base32_Decode编译: VS2012  C# (.NET Framework v2.0)组织: K8搞基大队[K8team]作者: K8拉登哥哥博客: http://qqhack8. ...

  3. 02-01 Java关键字、标识符、注释、常量和进制问题、变量和数据类型

    1:关键字 (1)被Java语言赋予特定含义的单词 (2)特点: 全部小写. (3)注意事项: A:goto和const作为保留字存在. B:类似于Notepad++这样的高级记事本会对关键字有特殊颜 ...

  4. Feign status 400 reading 问题分析

    背景:项目使用的是微服务架构,采用springboot来开发,所有的服务都是基于内嵌tomcat来运行 问题:项目部署到测试环境之后,偶尔在后台日志会看到这样的日志:Feign status 400 ...

  5. Hive执行过程中出现Caused by : java.lang.ClassNotFoundException: org.cloudera.htrace.Trace的错误解决办法(图文详解)

    不多说,直接上干货! 问题详情 如下 这个错误的意思是缺少 htrace-core-2.04.jar. 解决办法: 将$HBASE_HOME/lib下的htrace-core-2.04.jar拷贝到$ ...

  6. JavaScript -- Math

    ----- 016-Math.html ----- <!DOCTYPE html> <html> <head> <meta http-equiv=" ...

  7. linux buff/cache释放

    手动释放cache # > /proc/sys/vm/drop_caches

  8. 比特币算法——SHA256算法介绍

    SHA256是安全散列算法SHA(Secure Hash Algorithm)系列算法之一,其摘要长度为256bits,即32个字节,故称SHA256.SHA系列算法是美国国家安全局 (NSA) 设计 ...

  9. PTA (Advanced Level) 1009 Product of Polynomials

    1009 Product of Polynomials This time, you are supposed to find A×B where A and B are two polynomial ...

  10. Java NIO系列教程(十) Java NIO DatagramChannel

    Java NIO中的DatagramChannel是一个能收发UDP包的通道.因为UDP是无连接的网络协议,所以不能像其它通道那样读取和写入.它发送和接收的是数据包. 打开 DatagramChann ...