热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

5信息的表示和处理_整数表示

目录1无符号数编码2补码编码3有符号数和无符号数之间的转换3.1补码转为无符号数3.2无符号数转为补码4数字的位扩展5数字的位截断6C跟Java对无符号数的支持7额外补充Java相

目录



  • 1 无符号数编码

  • 2 补码编码

  • 3 有符号数和无符号数之间的转换

    • 3.1 补码转为无符号数

    • 3.2 无符号数转为补码



  • 4 数字的位扩展

  • 5 数字的位截断

  • 6 C跟Java对无符号数的支持

  • 7 额外补充Java相关的知识:

在讲述整数之前,先引入编码这个概念。因为计算机里面都是用 0/1串来表示一切的。使用到数值的时候,例如整数运算,需要先将整数转换成0/1的二进制表示,这个转换过程就叫编码。


1 无符号数编码

无符号数:用自然的二进制表示,取值范围只能是大于或者等于零的整数

无符号数特征每个介于0~2^x-1的数都有唯一一个x位的值编码。例如十进制21作为无符号数,只有一个5位的表示,即【10101】 。也就是说:在0~2^x-1之间的每一个整数都可以映射为一个唯一的长度为x的位模式




  1. 正整数或者0的无符号编码就是它的二进制形式

  2. 负整数没有其无符号编码,因为负数要用补码来表示



2 补码编码

补码用二进制表示,但是最高位为符号位,符号位是1表示负数,0表示非负数。因此补码的取值范围可能是大于0,等于0,少于0的整数。

基于符号位这一特征,计算机可以使用补码来表示负数 (不是指补码编码一定是负数,而是负数可以使用补码编码)

补码的范围是不对称的,x位补码的值表示范围:所能表示的最少值是[10……0],最高位设置成1,其它位设成0。最大值为[01……1],最高位设置成0,其它位设为1。

以长度4为例子,它的最小值表示是[1000] 即-8,最大值表示是[0111] 即7。所以取值范围是: -8~7。

关于补码的举例子1:

补码编码为【11 0001】,代表十进制数值:-1*2^5 + 1*2^4 +0*2^3 + 0*2^2 +1*2^0 = -32+16+1 = -15
补码编码为[1011] 代表十进制数:11
十进制数 -7的补码编码为:[1001] 。

继续举例2:

十进制12345的补码表示:0011 0000 0011 1001
十进制-12345的补码表示:1100 1111 1100 0111
十进制53191的无符号表示:1100 1111 1100 0111
发现,-12345的补码和53191的无符号的位表示是一样的。


  1. 因此,声明整型数值时需要明确表示它是有符号还是无符号的,否则,同样的位表示,可能会对应两个不同的整数。同时印证了,任何整数都有唯一一个位编码,但是一个位编码可能对应不同的整数

  2. C语言中,int代表是有符号整数,unsigned代表无符号整数


注意注意:

C语言标准并没有要求用补码来表示有符号整数,但几乎所有机器都这么做。 即:可以用补码来表示有符号整数


关于整数如何表示补码



  1. 先统一转换成十进制,并且确定它的位个数。

  2. 如果不小于0,那么补码就是其二进制原码

  3. 如果小于0,先计算出正数形式的二进制原码,然后取反,再对取反结果加上1,就得出补码。

    举例子:

比如-7的补码是1001
1、-7的正数表示:0111
2、0111,取反得到 1000
3、取反结果加上1:1001

3 有符号数和无符号数之间的转换

先说结论:


条件1:C语言

条件2:在具有相同字长的环境下

结论:强制类型转换后,数值可能会改变,但是位编码不变


怎么理解:

强制类型转换前后,底层表示的位编码不会变的,变化的是数值。

看例子:在用补码表示有符号数的机器下编译并运行以下代码

#include
int main(){
short int v = -12345;
unsigned short uv = (unsigned short)v;
printf("v=%d,uv=%u\n",v,uv);
return 1;
}

输出结果是:v=-12345,uv=53191

而-12345的补码编码跟53191的无符号编码有相同的位表示(上面的举例2已证明)


3.1 补码转为无符号数

转换规则:

先计算出补码,然后忽略最高位的负权重,作为自然的二进制

例如 -8 ,补码是1000 ,那么对应无符号数编码就是1000 ,对应十进制是8

例如 -3 ,补码是1011 ,那么对应无符号数编码就是1011 ,对应十进制是11

例如 5 , 补码是0101 ,那么对应无符号数编码就是0101 ,对应十进制是5


3.2 无符号数转为补码

例如 5 , 无符号数编码是0101 ,对应补码0101 ,对应十进制是5

例如 9 , 无符号数编码是10001 ,对应补码10001 ,对应十进制是-15


4 数字的位扩展

首先为什么会出现位扩展?

一个典型的例子就是,在不同字长的整数之家切换,同时又能保持数值不变。比某值如在32位系统中占4个字节,但是在64位系统占据8字节。




  1. 无符号数,0扩展,即高位补0

  2. 补码(有符号数),符号位扩展,即高位补扩展前高位的值


举个例子:-5的补码

向量 [1011] 可以是-5的补码
向量 [11011] 是-5的补码
向量 [111011] 是-5的补码
这表明,第二、三个 位向量可以通过第一个位向量做符号扩展得到

是不是觉得很神奇!!其实是通过数学证明过来的


5 数字的位截断

首先为什么会出现截断?扩展的反向情景,比如从2字节收缩为1字节。

比如当一个2字节的数,转化为1字节的数时,应截断去掉高位数据,那么仅仅去掉高位的数据就行了么,不需要额外的其他操作了吗? 答案是肯定的,只需要把高位去掉,保留低位就行。


1. 无符号数,高位去掉,保留低位。

2. 补码(有符号数),同样如此。



6 C跟Java对无符号数的支持

  1. C语言是为数不多的支持无符号数。有符号数到无符号数的隐式转换,可能会导致某些非直观的错误,建议都使用有符号数

  2. Java只支持有符号数,并且用补码的运算来表示。即用任意整数都用补码的方式来编码成二进制代码。


7 额外补充Java相关的知识:

JVM支持的所有整数数据类型-byte,short,int和long,他们都是带符号的二进制补码。在java中计算补码使用以下法则



  1. 正数的补码就是二进制序列。

  2. 负数的补码就是对反码加1,

用补码表示 -5,先变成二进制的原码,再取反变成反码,然后反码+1
0000 0101 (5) ----->1111 1010----->1111 1011 (-5) 补码


推荐阅读
  • 如何用UE4制作2D游戏文档——计算篇
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了如何用UE4制作2D游戏文档——计算篇相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • JavaScript设计模式之策略模式(Strategy Pattern)的优势及应用
    本文介绍了JavaScript设计模式之策略模式(Strategy Pattern)的定义和优势,策略模式可以避免代码中的多重判断条件,体现了开放-封闭原则。同时,策略模式的应用可以使系统的算法重复利用,避免复制粘贴。然而,策略模式也会增加策略类的数量,违反最少知识原则,需要了解各种策略类才能更好地应用于业务中。本文还以员工年终奖的计算为例,说明了策略模式的应用场景和实现方式。 ... [详细]
  • Voicewo在线语音识别转换jQuery插件的特点和示例
    本文介绍了一款名为Voicewo的在线语音识别转换jQuery插件,该插件具有快速、架构、风格、扩展和兼容等特点,适合在互联网应用中使用。同时还提供了一个快速示例供开发人员参考。 ... [详细]
  • 云原生边缘计算之KubeEdge简介及功能特点
    本文介绍了云原生边缘计算中的KubeEdge系统,该系统是一个开源系统,用于将容器化应用程序编排功能扩展到Edge的主机。它基于Kubernetes构建,并为网络应用程序提供基础架构支持。同时,KubeEdge具有离线模式、基于Kubernetes的节点、群集、应用程序和设备管理、资源优化等特点。此外,KubeEdge还支持跨平台工作,在私有、公共和混合云中都可以运行。同时,KubeEdge还提供数据管理和数据分析管道引擎的支持。最后,本文还介绍了KubeEdge系统生成证书的方法。 ... [详细]
  • 本文介绍了一个Java猜拳小游戏的代码,通过使用Scanner类获取用户输入的拳的数字,并随机生成计算机的拳,然后判断胜负。该游戏可以选择剪刀、石头、布三种拳,通过比较两者的拳来决定胜负。 ... [详细]
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • 目录实现效果:实现环境实现方法一:基本思路主要代码JavaScript代码总结方法二主要代码总结方法三基本思路主要代码JavaScriptHTML总结实 ... [详细]
  • Android中高级面试必知必会,积累总结
    本文介绍了Android中高级面试的必知必会内容,并总结了相关经验。文章指出,如今的Android市场对开发人员的要求更高,需要更专业的人才。同时,文章还给出了针对Android岗位的职责和要求,并提供了简历突出的建议。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • LeetCode笔记:剑指Offer 41. 数据流中的中位数(Java、堆、优先队列、知识点)
    本文介绍了LeetCode剑指Offer 41题的解题思路和代码实现,主要涉及了Java中的优先队列和堆排序的知识点。优先队列是Queue接口的实现,可以对其中的元素进行排序,采用小顶堆的方式进行排序。本文还介绍了Java中queue的offer、poll、add、remove、element、peek等方法的区别和用法。 ... [详细]
  • 树莓派Linux基础(一):查看文件系统的命令行操作
    本文介绍了在树莓派上通过SSH服务使用命令行查看文件系统的操作,包括cd命令用于变更目录、pwd命令用于显示当前目录位置、ls命令用于显示文件和目录列表。详细讲解了这些命令的使用方法和注意事项。 ... [详细]
  • 原文地址:https:www.cnblogs.combaoyipSpringBoot_YML.html1.在springboot中,有两种配置文件,一种 ... [详细]
author-avatar
阿门路亚_
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有