3 数据类型、运算符与表达式-3.3.2 整型变量(原码,反码,补码)

本文主要是介绍3 数据类型、运算符与表达式-3.3.2 整型变量(原码,反码,补码),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在计算机科学中,补码、原码和反码是用来表示带符号整数的二进制编码方法,特别是在计算机内存中存储和处理整数时。这些编码方式帮助计算机区分正数和负数,并支持算术运算。以下是它们的具体含义:

原码(True Form or Sign-and-Magnitude)

  • 定义:原码是最直接的表示方法,用最高位来表示符号(0表示正数,1表示负数),其余位表示数值的绝对值。例如,+3的原码为0011,而-3的原码为1011。
  • 特点:简单直观,但直接使用原码进行加法运算时,正数与负数的加法会出现问题,因为符号位会直接相加。

反码(Ones’ Complement)

  • 定义:反码是为了解决原码加法问题而引入的,对于正数,反码与原码相同;对于负数,除了符号位保持不变,数值位上的每一位都取反(0变成1,1变成0)。例如,+3的反码依然是0011,而-3的反码则是1100。
  • 特点:使用反码进行加法运算可以正确处理正数加负数的情况,但是0有两种表示(+0和-0),且减法运算依然不直接。

补码(Two’s Complement)

  • 定义:补码是在反码的基础上,对负数的反码再加1得到的。正数的补码与原码、反码相同。例如,+3的补码为0011,而-3的补码是1101(先取反得到1100,再加1)。
  • 特点
    • 唯一性:所有数(包括正数、负数和零)都有唯一的补码表示,消除了+0和-0的问题。
    • 方便计算:使用补码可以直接进行加法和减法运算,无需区分操作,因为减一个数等同于加上它的补码。
    • 溢出处理:补码还能自然处理溢出问题,使得计算机在处理算术运算时可以忽略溢出情况,简化硬件设计。

总结:在现代计算机系统中,补码是最常用的表示方法,因为它简化了硬件设计,并且使得加法、减法运算以及溢出的处理变得统一和高效。原码和反码在教学中主要用于解释补码的概念,以及理解计算机系统的历史发展。

了解您想看关于原码、反码、补码的实际应用案例,下面我将通过一个简单的C语言示例来演示如何在实际编程中使用这些概念来处理有符号整数的运算。这个例子将会展示如何手动计算一个负数的原码、反码和补码,并用补码形式执行加法运算。

实战案例:计算负数的补码并进行加法运算

#include <stdio.h>// 手动计算负数的补码
unsigned int calculateTwosComplement(int number) {if (number >= 0) return number; // 正数的补码等于其原码unsigned int absNumber = -(unsigned int)number; // 获取绝对值的无符号表示return ~(absNumber) + 1; // 取反后加1得到补码
}int main() {int a = -5; // 示例中的负数int b = 3; // 示例中的正数// 计算a的补码unsigned int a_twos_complement = calculateTwosComplement(a);printf("数字 %d 的补码是:%u\n", a, a_twos_complement);// 将a的补码转换回原码表示,仅为了展示原码和反码的计算过程int a_original = (int)a_twos_complement;if (a < 0) a_original = -((int)~a_twos_complement + 1);printf("数字 %d 的原码是:%d\n", a, a_original);// 注意:在实际计算机内存中,a直接以补码形式存储,不会手动转换回原码// 使用补码进行加法运算// 注意:直接使用C语言的加法运算符即可,因为编译器内部会处理补码运算int sum = a + b;printf("-%d 加上 %d 的结果(使用补码计算)是:%d\n", a, b, sum);return 0;
}

解释

  • 上述代码首先定义了一个函数calculateTwosComplement,用于计算一个整数的补码。特别地,如果输入是正数或零,函数直接返回原值(因为正数的补码等于其原码);如果是负数,则先取绝对值转换为无符号整数,然后对每位取反,最后加1得到补码。
  • main函数中,我们定义了两个整数变量ab,分别代表一个负数和一个正数。我们通过调用calculateTwosComplement函数计算a的补码,并打印出来。
  • 接着,为了教学目的,我们手动演示了如何从补码恢复到原码的过程,但实际上在计算机中我们不需要做这个转换,因为计算机会直接使用补码进行运算。
  • 最后,我们通过简单的加法运算a + b展示了在C语言中,即使是负数和正数的加法,也能直接进行,这是因为编译器底层处理的是补码形式的数值。

这个例子展示了补码在实际编程中的应用,尤其是在处理有符号整数运算时,补码提供了便利和效率。
在这里插入图片描述

在这里插入图片描述

【例3.2 】整型变量的定义与使用。

main()
{
int a,b,c,d;
unsigned u;
a=12;b=-24;u=10;
c=a+u;d=b+u;
printf(“a+u=%d,b+u=%d\n”,c,d);
}

【例 3.3】整型数据的溢出。

main() 
{ a=32767b=a+1; printf("%}

【例 3.4】

main() 
{ long x,y; int a,b,c,d; x=5; y=6; a=7; b=8; c=x+a;d=y+b; printf("c=x+a=%d,d=y+b=%d\n",c,d); }

这篇关于3 数据类型、运算符与表达式-3.3.2 整型变量(原码,反码,补码)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1050266

相关文章

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

变量与命名

引言         在前两个课时中,我们已经了解了 Python 程序的基本结构,学习了如何正确地使用缩进来组织代码,并且知道了注释的重要性。现在我们将进一步深入到 Python 编程的核心——变量与命名。变量是我们存储数据的主要方式,而合理的命名则有助于提高代码的可读性和可维护性。 变量的概念与使用         在 Python 中,变量是一种用来存储数据值的标识符。创建变量很简单,

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

06 C++Lambda表达式

lambda表达式的定义 没有显式模版形参的lambda表达式 [捕获] 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 有显式模版形参的lambda表达式 [捕获] <模版形参> 模版约束 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 含义 捕获:包含零个或者多个捕获符的逗号分隔列表 模板形参:用于泛型lambda提供个模板形参的名

C 语言的基本数据类型

C 语言的基本数据类型 注:本文面向 C 语言初学者,如果你是熟手,那就不用看了。 有人问我,char、short、int、long、float、double 等这些关键字到底是什么意思,如果说他们是数据类型的话,那么为啥有这么多数据类型呢? 如果写了一句: int a; 那么执行的时候在内存中会有什么变化呢? 橡皮泥大家都玩过吧,一般你买橡皮泥的时候,店家会赠送一些模板。 上

【重学 MySQL】十九、位运算符的使用

【重学 MySQL】十九、位运算符的使用 示例检查权限添加权限移除权限 在 MySQL 中,位运算符允许你直接在整数类型的列或表达式上进行位级操作。这些操作对于处理那些需要在二进制表示上进行直接修改或比较的场景特别有用,比如权限管理、状态标记等。 &(位与) 对两个数的二进制表示进行位与操作。只有两个相应的二进制位都为 1 时,结果的该位才为 1,否则为 0。 |(位

如何掌握面向对象编程的四大特性、Lambda 表达式及 I/O 流:全面指南

这里写目录标题 OOP语言的四大特性lambda输入/输出流(I/O流) OOP语言的四大特性 面向对象编程(OOP)是一种编程范式,它通过使用“对象”来组织代码。OOP 的四大特性是封装、继承、多态和抽象。这些特性帮助程序员更好地管理复杂的代码,使程序更易于理解和维护。 类-》实体的抽象类型 实体(属性,行为) -》 ADT(abstract data type) 属性-》成

Java基础回顾系列-第三天-Lambda表达式

Java基础回顾系列-第三天-Lambda表达式 Lambda表达式方法引用引用静态方法引用实例化对象的方法引用特定类型的方法引用构造方法 内建函数式接口Function基础接口DoubleToIntFunction 类型转换接口Consumer消费型函数式接口Supplier供给型函数式接口Predicate断言型函数式接口 Stream API 该篇博文需重点了解:内建函数式

C语言程序设计(数据类型、运算符与表达式)

一、C的数据类型 C语言提供的数据类型: 二、常量和变量 2.1常量和符号常量 在程序运行过程中,其值不能被改变的量称为常量。 常量区分为不同的类型: 程序中用#define(预处理器指令)命令行定义变量将代表常量,用一个标识符代表一个常量,称为符合常量。 2.2变量 变量代表内存中具有特定属性的一个存储单元,用来存放数据,在程序运行期间,这些值是可以 改变的。 变

JavaSE(十三)——函数式编程(Lambda表达式、方法引用、Stream流)

函数式编程 函数式编程 是 Java 8 引入的一个重要特性,它允许开发者以函数作为一等公民(first-class citizens)的方式编程,即函数可以作为参数传递给其他函数,也可以作为返回值。 这极大地提高了代码的可读性、可维护性和复用性。函数式编程的核心概念包括高阶函数、Lambda 表达式、函数式接口、流(Streams)和 Optional 类等。 函数式编程的核心是Lambda