服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C/C++ - C语言详细解析有符号数与无符号数的表示

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

2022-11-13 14:06清风自在 流水潺潺 C/C++

我们知道,在C语言中存在无符号数和有符号数,但是对于计算机而言,其本身并不区别有符号数和无符号数,因为在计算机里面都是O或者1,但是在我们的实际使用中有时候需要使用有符号数来表示一个整数,因此我们规定,当最

一、计算机中的符号位

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

  • 最高位为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;
}

下面为输出结果:

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

这段代码核心思想就是判断最高位为是不是 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;
}

下面为输出结果:

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

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;
}

下面为部分输出结果:

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

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

五、小结

有符号数用补码表示

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

无符号数用原码表示

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

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

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

原文链接:https://blog.csdn.net/weixin_43129713/article/details/122676555

延伸 · 阅读

精彩推荐
  • C/C++C语言 fseek(f,0,SEEK_SET)函数案例详解

    C语言 fseek(f,0,SEEK_SET)函数案例详解

    这篇文章主要介绍了C语言 fseek(f,0,SEEK_SET)函数案例详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下...

    andy89121810612021-12-22
  • C/C++C语言去除相邻重复字符函数的实现方法

    C语言去除相邻重复字符函数的实现方法

    这篇文章主要介绍了C语言去除相邻重复字符函数的实现方法的相关资料,实现去重字符串相邻重复的字符,不相邻的不用去重的功能,需要的朋友可以参考...

    yonj1e8582021-05-27
  • C/C++C++小知识:尽可能使用枚举类

    C++小知识:尽可能使用枚举类

    今天小编就为大家分享一篇关于C++小知识:尽可能使用枚举类,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来...

    修语讲编程6392021-07-18
  • C/C++C++ 操作系统内存分配算法的实现详解

    C++ 操作系统内存分配算法的实现详解

    本文主要介绍了在动态分区管理方式下采用不同的分配算法实现主存分配和实现主存回收,旨在帮助学生理解在动态分区管理方式下应怎样实现主存空间的...

    Carmelo_77892022-02-25
  • C/C++c++实现对输入数组进行快速排序的示例(推荐)

    c++实现对输入数组进行快速排序的示例(推荐)

    下面小编就为大家带来一篇c++实现对输入数组进行快速排序的示例(推荐)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来...

    jingxian11222021-05-14
  • C/C++构造函数不能声明为虚函数的原因及分析

    构造函数不能声明为虚函数的原因及分析

    构造函数不需要是虚函数,也不允许是虚函数,因为创建一个对象时我们总是要明确指定对象的类型,尽管我们可能通过实验室的基类的指针或引用去访问...

    C语言教程网5532021-01-05
  • C/C++C++中缀表达式转后缀表达式的方法

    C++中缀表达式转后缀表达式的方法

    这篇文章主要介绍了C++中缀表达式转后缀表达式的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    WuYaoBing9272021-09-02
  • C/C++c++与python实现二分查找的原理及实现

    c++与python实现二分查找的原理及实现

    本文介绍了c++与python实现二分查找的原理及实现,二分查找指首先将数组中间值和目标值进行比较,如果相等则返回;如果不相等,则选择中间值左边的一...

    机器学习入坑者6642022-10-17