- 浏览: 1587010 次
- 性别:
- 来自: 吉林
文章分类
- 全部博客 (624)
- C/C++ (33)
- Java (181)
- 网络相关 (7)
- 我爱篮球 (3)
- 也爱足球 (4)
- 杂谈 (1)
- 系统架构 (3)
- Web Service (14)
- Framework (3)
- 系统命令 (8)
- 管理平台相关 (8)
- 其它 (35)
- Websphere (1)
- Struts2 (24)
- Hibernate (16)
- Spring (23)
- javascript (20)
- jquery (23)
- html/css/div (28)
- 数据库 (40)
- JavaWeb (27)
- 设计模式 (2)
- 文档编写 (3)
- SVN (5)
- Ant (1)
- Maven (13)
- 软件项目管理 (8)
- AOP (1)
- kindeditor (1)
- JSON (2)
- Servlt/JSP (4)
- WordXML (2)
- XML (12)
- 面试相关 (7)
- Tomcat (11)
- 性能与调优 (29)
- 职业发展 (2)
- 操作系统 (7)
- AJAX (2)
- DWR (1)
- Eclipse (12)
- 持续集成 (3)
- 批处理命令 (1)
- Mozilla Rhino (2)
- 新鲜技术 (18)
- Apache mina (2)
- 底层技术 (18)
- Linux (22)
- 新鲜技术,IT历史 (1)
- 敏捷开发 (1)
- 版本控制 (5)
- 较火技术 (7)
- 集群 (2)
- Web前端 (13)
- 报表工具 (3)
- 网站架构 (5)
- 大数据 (8)
- 分布式存储 (5)
- 云计算 (8)
- TCP/IP协议 (1)
- 负载均衡 (3)
- 硬件 (1)
- 表现层技术 (3)
- Velocity (3)
- jvm (6)
- 并发编程 (10)
- hadoop (8)
- 数据结构和算法 (12)
- 计算机原理 (1)
- 测试驱动开发-TDD (3)
- 开发技巧 (1)
- 分词器 (1)
- 项目构建工具 (2)
- JMX (4)
- RMI (1)
- 测试技术 (22)
- 网络完全 (1)
- Git (4)
- apache开源包 (4)
- Java常用 (1)
- mock (2)
- OSGi (2)
- MongoDB (1)
- JBPM (1)
- Storm (3)
- mysql (2)
- telnet (1)
- 正则表达式 (1)
- bootstrap (4)
- Apache ActiveMQ (1)
- redis (9)
- Nginx (2)
- rsync+inotify文件同步 (2)
- testng (1)
- 原型设计工具 (1)
- 工程能力 (1)
- 风险控制 (3)
- ibatis (1)
- 分布式 (4)
- 安全技术 (1)
- 计算机基础 (4)
- 消息中间件 (1)
- UML (2)
最新评论
-
u012236967:
java命令执行jar包(里面的main函数)的方式(包括依赖其它的jar包问题) -
世界尽头没有你:
Selenium自动化测试从入门到精通(Java版)百度网盘地 ...
自动化测试工具 Selenium WebDriver 入门教程(针对主流浏览器) -
小小西芹菜:
我喜欢代码简洁易读,服务稳定的推送服务,前段时间研究了一下go ...
dwr实现Reverse Ajax推送技术的三种方式 -
hellozhouqiao:
楼主,请教一点问题.现在我们需要在excel 的页脚里面加上图 ...
FreeMaker + xml 导出word(处理目录,图片和页眉页脚问题) -
乱在长安:
使用Timer会有各种各样的问题好嘛?!书上推荐使用Sched ...
DelayQueue (ScheduledThreadPoolExecutor调度的实现)
int a = 128;
byte b = (byte)a;
那么b = -128,为什么?
第一种理解:
byte的表示范围是-128到+127,128的二进制表示是0000000010000000,若将其强制转换为byte型,则只留下10000000,即-128 。
譬如byte=137,明显超出了byte所能表示的范围;所以取其二进制表示:10001001
首先最高位表示符号位,所以输出结果应该是负数,将其取反变为01110110,加1变为01110111,再将其转化为十进制输出:-119。
第二种理解:
byte可以表示 -128~127之间共256个数,当强制转换一个大于的数a相应的结果为a-256;当强制转换一个小于-128的数b相应结果为b+256
假设有一 int 类型的数,值为5,那么,我们知道它在计算机中表示为: 00000000 00000000 00000000 00000101 5转换成二制是101,不过int类型的数占用4字节(32位),所以前面填了一堆0。 现在想知道 ...
假设有一 int 类型的数,值为5,那么,我们知道它在计算机中表示为:
00000000 00000000 00000000 00000101
5转换成二制是101,不过int类型的数占用4字节(32位),所以前面填了一堆0。
现在想知道,-5在计算机中如何表示?
在计算机中,负数以其正值的补码形式表达。
什么叫补码呢?这得从原码,反码说起。
原码:一个整数,按照绝对值大小转换成的二进制数,称为原码。
比如 00000000 00000000 00000000 00000101 是 5的 原码。
反码:将二进制数按位取反,所得的新二进制数称为原二进制数的反码。
取反操作指:原为1,得0;原为0,得1。(1变0; 0变1)
比如:将00000000 00000000 00000000 00000101每一位取反,得11111111 11111111 11111111 11111010。
称:11111111 11111111 11111111 11111010 是 00000000 00000000 00000000 00000101 的反码。
反码是相互的,所以也可称:
11111111 11111111 11111111 11111010 和 00000000 00000000 00000000 00000101 互为反码。
补码:反码加1称为补码。
也就是说,要得到一个数的补码,先得到反码,然后将反码加上1,所得数称为补码。
比如:00000000 00000000 00000000 00000101 的反码是:11111111 11111111 11111111 11111010。
那么,补码为:
11111111 11111111 11111111 11111010 1 = 11111111 11111111 11111111 11111011
所以,-5 在计算机中表达为:11111111 11111111 11111111 11111011。转换为十六进制:0xFFFFFFFB。
再举一例,我们来看整数-1在计算机中如何表示。
假设这也是一个int类型,那么:
1、先取1的原码:00000000 00000000 00000000 00000001
2、得反码: 11111111 11111111 11111111 11111110
3、得补码: 11111111 11111111 11111111 11111111
正数的原码,补码,反码都相同,都等于它本身
负数的补码是:符号位为1,其余各位求反,末位加1
反码是:符号位为1,其余各位求反,但末位不加1
也就是说,反码末位加上1就是补码
1100110011 原
1011001100 反 除符号位,按位取反
1011001101 补 除符号位,按位取反再加1
正数的原反补是一样的
在计算机中,数据是以补码的形式存储的:
在n位的机器数中,最高位为符号位,该位为零表示为正,为1表示为负;
其余n-1位为数值位,各位的值可为0或1。
当真值为正时:原码、反码、补码数值位完全相同;
当真值为负时: 原码的数值位保持原样,
反码的数值位是原码数值位的各位取反,
补码则是反码的最低位加一。
注意符号位不变。
如:若机器数是16位:
十进制数 17 的原码、反码与补码均为: 0000000000010001
十进制数-17 的原码、反码与补码分别为:1000000000010001、1111111111101110、1111111111101111
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/shawnsoft/archive/2009/12/16/5010139.aspx
发表评论
-
COM(Component Object Model)组件介绍
2013-01-15 17:38 1516COM component(COM组件)是微软公司为了计算机 ... -
scanf的用法
2012-05-31 23:37 1465scanf()函数的用法和实 ... -
定义计算变量相对于结构体偏移量的宏
2012-05-30 22:42 2819#include <stdio.h> #incl ... -
C语言一些有用的宏定义
2012-05-30 22:36 1767C语言宏定义技巧(常用宏定义) 写好C语 ... -
C语言const
2012-05-30 14:35 1261原文地址:http://hi.baidu. ... -
C语言void指针
2012-05-29 09:50 13611.概述 本文将对void关键字的深刻含义进行解说,并 ... -
C语言中#line 宏说明
2012-05-28 09:38 1845c语言里有个很少用到的宏 #line,这个宏通常是和__LIN ... -
C语言中宏的一些特别用法
2012-05-28 09:36 1726转载 C语言中如何使用宏C(和C++)中的宏(Macro)属 ... -
C语言编译执行的全过程
2012-05-28 09:13 1238编译,编译程序读取源程序(字符流),对之进行词法和语法的分 ... -
C++新型头文件与名称空间的作用
2012-05-25 09:06 18701.20 新型头文件与名字 ... -
程序在内存中运行的奥秘
2010-07-01 12:18 1843内存管理是操作系统的核心功能,无论对于开发者还是系统管理员内存 ... -
堆和栈的区别
2010-06-29 10:56 1650栈是随函数被调用时分 ... -
链表常见笔试题
2010-06-25 11:22 3466链表的一些常见笔试面试问题总结及代码 ... -
C与C++中struct的区别,以及C++中struct与Class的区别
2010-06-25 10:44 4196C中struct只可以放成员变量,没有访问权限限制,外部可以访 ... -
C++中的inline用法总结
2010-05-26 22:26 18809inline函数的作用 ... -
C++枚举类型用途及定义详解
2010-05-26 21:14 4579C++编程语言作为一种功 ... -
C++ Template 中的typename、class关键字区别
2010-05-19 19:27 3322在c++Template中很多地 ... -
C++与Java比较(转)
2010-04-30 23:02 4460“作为一名C++程序员,我们早已掌握了面向对象程序设计的基本概 ... -
几款常见C++编译器的比较
2010-04-30 22:58 5727另外,就我个人的一点点经验来看,vs 2005中的C++编译器 ... -
C/C++编译过程理解
2010-04-30 22:31 2742标准C和C++将编译过程定义为9个阶段(Phases of T ...
相关推荐
在计算机科学中,二进制表示的数字有三种主要形式:原码、反码和补码,主要用于表示有符号整数。本项目是基于C++的MFC(Microsoft Foundation Classes)框架实现的一个实用工具,旨在帮助用户理解并进行原码、反码和...
注意:(-128) 没有相对应的原码和反码,(-128) = (10000000)。 补码的加减运算如下:(1)10 - (1)10 = (1)10 + (-1)10 = (0)10(00000001)补 + (11111111)补 = (00000000)补 = (0) 正确(1)10 - (2)10 = (1)10 +...
注意,8位反码的范围是-127(11110001B)到+127(01111111B),但-128(10000000B)是一个特殊值,其反码与原码相同,因为它是通过在原码基础上逐位取反得到的,而不能简单地理解为-127加1。 3. **补码**: 补码是...
计算机原理原码、反码、补码 计算机原理中,整数的表示方式有三种:原码、反码和补码。这些概念都是为了解决整数在计算机中的表示和存储问题。 首先,让我们来了解一下整数在计算机中的表示范围。一个字节的整数...
需要注意的是,由于加1,负数的补码比其原码多一个数值,即-128,这个数没有原码和反码。而正数的原码、反码和补码都是相同的。 在编程中,尤其是在Java、C++等语言中,强制类型转换可能会导致数据溢出。例如,将一...
在8位系统中,-128的补码表示为10000000,而其原码表示为11111111取反后加1,即10000000。 在进行位运算时,理解原码、反码和补码的转换规则非常关键,因为它们直接影响计算结果。例如,位左移、位右移等操作在正...
但特别的是,当最高位为1时,补码也可以表示-128(10000000)。这是因为补码系统允许我们进行减法操作而不必额外处理溢出情况。 总结来说,这个PPT学习教案详细介绍了二进制、八进制和十六进制之间的转换方法,以及...
- **`byte`**:8 位补码表示,范围为 -128 至 127。 - **`short`**:16 位补码表示,范围为 -32768 至 32767。 - **`int`**:32 位补码表示,范围为 -2^31 至 2^31-1。 - **`long`**:64 位补码表示,范围为 -2^63 ...
在Java编程语言中,数值类型的数据在计算机内部是以二进制形式存储的,这就涉及到原码、反码和补码的概念。这些编码方式主要用于表示有符号整数,尤其是负数的表示。 1. 原码 原码是最直接的表示方式,其中最高位...
以8位为例,正数的补码就是它自身的原码(即直接的二进制表示),而负数的补码是它的反码(所有位取反)加1。例如,-1的8位补码是11111111,因为它的原码(00000001)取反得到11111110,再加上1得到11111111。 当...
在Java中,byte是一个8位的有符号整型数据,它的取值范围是-128到127。int是一个32位的有符号整型数据,取值范围是-2,147,483,648到2,147,483,647。由于byte与int的数据位数不同,转换时需要进行特定的处理。 **...
本资源摘要信息涵盖了Java基础50题2023新版的知识点,涵盖了基础概念、环境变量配置、命令行编程、进制转换、原码补码反码、数据类型转换、算术运算符、浮点数、位运算符、表达式、读程序题、标识符命令规范、键盘...
- **补码**:正数的补码与其原码相同,负数的补码是在其反码的基础上,最低位加1。 - 示例: - \((-35)\) 的二进制表示为 \((-100011)_2\)。 - 原码:\(1100011\) - 反码:\(1011100\) - 补码:\(1011101\) -...
在主循环中,程序会根据输入的整数打印其真值、原码(对于-128无效)、反码和补码。 在学习这个实验报告时,学生需要理解以下几个关键概念: - ASCII码:一种字符编码标准,包含128个不同的字符,每个字符对应一个7...
- 8位二进制补码能表示的整数范围是-128(10000000B)到+127(01111111B),因此答案是D. -128~+127。 9. 数值计算: - 8位二进制补码由5个1和3个0组成,最大值为11111000B,对应-8;最小值是11111001B,对应-121...
而补码则是用来解决减法问题的,它在原码的基础上对负数的反码加1。补码让减法运算可以通过加法实现,例如,-7的补码是11111001,这是因为-7的反码加1得到它。补码表示的+0和-0是不同的,+0的补码为00000000,而-0的...
原码、反码、补码 - **原码**: 数的原码表示在机器中用符号位的0和1表示数的正负号,而其余表示其数本身。 - **反码**: 对于正数,反码与原码相同;对于负数,反码与原码的符号位不变,数值各位取反。 - **补码**: ...
- 对于正数而言,其原码、反码和补码是相同的。 - **正确答案:** 对 26. **负数的原码与补码转换** - 负数的原码的反码的反码仍然是原码本身。 - **正确答案:** 对 27. **正负数的原码与补码转换** - 无论...