C语言详细解析有符号数与无符号数的表示

 更新时间:2022年04月20日 16:53:20   作者:清风自在 流水潺潺  
我们知道,在C语言中存在无符号数和有符号数,但是对于计算机而言,其本身并不区别有符号数和无符号数,因为在计算机里面都是O或者1,但是在我们的实际使用中有时候需要使用有符号数来表示一个整数,因此我们规定,当最高位为1的时,表示为负数,最高位为0时,表示为正数

一、计算机中的符号位

数据类型的最高位用于标识数据的符号

  • 最高位为1,表明这个数为负数
  • 最高位为0,表明这个数为正数

下面看一段代码,用于判断数据的符号:

#include <stdio.h>
int main()
{
    char c = -5;
    short s = 6;
    int i = -7;
    printf("%d\n", ( (c & 0x80) != 0 ));
    printf("%d\n", ( (s & 0x8000) != 0 ));
    printf("%d\n", ( (i & 0x80000000) != 0 ));
    return 0;
}

下面为输出结果:

这段代码核心思想就是判断最高位为是不是 1,再做逻辑运算,如果为 1,那么运算后就是 1,否则就是 0 。

二、有符号数的表示法

在计算机内部用补码表示有符号数

  • 正数的补码为正数本身
  • 负数的补码为负数的绝对值各位取反后加1

如:

8位整数 5 的补码为:0000 0101

8位整数 -7 的补码为:11111001

16位整数 20 的补码为:0000 0000 0001 0100

16位整数- 13 的补码为:1111 1111 1111 0011

三、无符号数的表示法

在计算机内部用原码表示无符号数

  • 无符号数默认为正数
  • 无符号数没有符号位

对于固定长度的无符号数

  • MAX_VALUE(所能表示的最大值)+ 1 --> MIN_VALUE(所能表示的最小值)
  • MIN_VALUE - 1 --> MAX_VALUE

四、signed 和 unsigned

  • C 语言中变量默认为有符号的类型
  • unsigned 关键字声明变量为无符号类型

注意:C语言中只有整数类型能够声明 unsigned 变量

下面看一段无符号数碰上有符号数的代码:

#include <stdio.h>
int main()
{
    unsigned int i = 5;
    int j = -10;
    if( (i + j) > 0 )
    {
        printf("i + j > 0\n");
    }
    else
    {
        printf("i + j <= 0\n");
    }
    return 0;
}

下面为输出结果:

i 为 5,j 为 -10,按理说两者相加应该输出为 i + j < 0,为什么会大于 0 呢?这是因为当无符号数与有符号数混合计算时,会将有符号数转换为无符号数后再进行计算,结果为无符号数。

再来看一个错误使用 unsigned 的例子:

#include <stdio.h>
int main()
{
    unsigned int i = 0;
    for(i=9; i>=0; i--)
    {
        printf("i = %u\n", i);
    }
    return 0;
}

下面为部分输出结果:

这是由于 i 为 unsigned 类型,减到 0 后,再减1,就变成了最大值,所以程序就会这样输出。

五、小结

有符号数用补码表示

  • 正数的符号位为0
  • 负数的符号位为1

无符号数用原码表示

  • 无符号数没有符号位
  • 无符号数只用于表示正数

unsigned 只能修饰整数类型的变量

到此这篇关于C语言详细解析有符号数与无符号数的表示的文章就介绍到这了,更多相关C语言有符号数与无符号数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C++ 实现汉诺塔的实例详解

    C++ 实现汉诺塔的实例详解

    这篇文章主要介绍了C++ 实现汉诺塔的实例详解的相关资料,这里主要说明C++中数据结构的递归的应用,需要的朋友可以参考下
    2017-08-08
  • C++ 继承的范例讲解

    C++ 继承的范例讲解

    继承是C++面向对象编程中的一门。继承是子类继承父类的特征和行为,或者是继承父类得方法,使的子类具有父类得的特性和行为。重写是子类对父类的允许访问的方法实行的过程进行重新编写,返回值和形参都不能改变。就是对原本的父类进行重新编写,但是外部接口不能被重写
    2022-06-06
  • C++与C#互调dll的实现步骤

    C++与C#互调dll的实现步骤

    这篇文章主要介绍了C++与C#互调dll的实现步骤,dll动态链接库的共享在一些大型项目中有一定的应用价值,需要的朋友可以参考下
    2014-08-08
  • Qt设计时钟效果

    Qt设计时钟效果

    这篇文章主要为大家详细介绍了Qt设计时钟效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-05-05
  • 详解C++ 多态的实现及原理

    详解C++ 多态的实现及原理

    这篇文章主要介绍了C++ 多态的实现及原理,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-05-05
  • 详解QT使用QtGui显示QImage的几种方法

    详解QT使用QtGui显示QImage的几种方法

    本文主要介绍了QT使用QtGui显示QImage的几种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-06-06
  • C++填坑的重写,重载和隐藏的详解

    C++填坑的重写,重载和隐藏的详解

    这篇文章主要介绍了C++中重载、重写(覆盖)和隐藏的区别,是C++面向对象程序设计非常重要的概念,需要的朋友可以参考下,希望能够给你带来帮助
    2021-09-09
  • 详解C++编程中的虚函数

    详解C++编程中的虚函数

    这篇文章主要介绍了详解C++编程中的虚函数,包括在什么情况下应当声明虚函数的相关讲解,需要的朋友可以参考下
    2015-09-09
  • C/C++中提高查找速度的小技巧

    C/C++中提高查找速度的小技巧

    这篇文章主要给大家介绍了C/C++中提高数组中查找某个元素或者字符串中查找某个字符效率的小技巧,提高速度对我们日常开发来说还是很有用的,文中给出了详细的示例代码,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-01-01
  • C++实现FTP综合应用详解

    C++实现FTP综合应用详解

    这篇文章主要为大家详细介绍了C++实现FTP综合应用,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-08-08

最新评论