深入解析unsigned int 和 int

article/2025/10/15 4:21:00
以下是对unsigned int和int进行了详细的分析介绍,需要的朋友可以过来参考下

就如同int a;一样,int 也能被其它的修饰符修饰。除void类型外,基本数据类型之前都可以加各种类型修饰符,类型修饰符有如下四种:
1.signed----有符号,可修饰char、int。int是默认有符号的。
2.unsigned-----无符号,修饰int 、char,short等
3.long------长型,修饰int 、double等
4.short------短型,修饰int

我们主要来看一下signed和unsigned与int之间的联系与区别。
什么叫做有符号,什么叫做无符号
这个问题其实很简单,比如:5和-5,5没有符号,-5有符号。简单吧。但是在计算机中的这种符号可不简单。我们分别来看一下:
在说明有符号和无符号的区别之前,我们必须先知道溢出是怎么回事,因为有无符号的根本原因可以说就是因为数据出现了溢出现象导致的。

溢出:
我们知道数据在计算机中以二进制存储,并且占据一定的空间,而这个空间属于计算机分配的空间。
计算机给int分配32位或者16位(不同电脑可能不同,目前的64位电脑int是64bit)的空间,既然空间有限,那么数值就会有限制,就会存在最大值与最小值这一说,比如:假设int类型的分配16位,无符号类型的最大值为1111 1111 1111 1111(16个1),也就是65535,如果超过了65535,这就叫做溢出,那该怎么办? 如果要输出65536,那将会输出个什么东西呢? 下面和大家一起看一下:

疑问:有的读者会问:65535这么小啊,我记得自己在输出比65535大好多的数也能够输出啊。
解答: 那就是有无符号的定义和你电脑编译器的原因了。64位的电脑和32的电脑可是不一样的哦。而且int占几个字节是与电脑编译器有关的。不过现在大部分电脑int占4个字节,即32位,那么他的最大值可是32个1(二进制)左右的数量级,你实验过这么大的数吗?

1.无符号整型(unsigned  int)
(1)我们都知道整型是4个字节(有些编译器不同,可能会是2个),即32位,无符号整型当然也为32位。
(2)既然是32位,无符号整型的取值是32个0~32个1,即:0~4294967295
(3) 我们举个例子:32位有点长,所以我们拿16位的unsigned short int 来举例,以下的所有举例均拿这个数字来说事了。


无符号short 类型范围是0~65535,二进制表示:0000 0000 0000 0000 -- 1111 1111 1111 1111

有符号short 类型范围是0~32767它的二进制为:0000 0000 0000 0000 -- 0111 1111 1111 1111


对于无符号的short类型来说,它的二进制的最高位称为数据位,即那个0就是数据位,数据位是要参与运算的,如果我们把0改成1,即16个1,它的十进制就是65535(就是2的15次方+2的14次方...一直加到2的0次方),这是不同于有符号整型的。
(4) 为了进行理解(3)中的含义,做一个程序说明:

复制代码 代码如下:
#include <stdio.h>
main()
{unsigned short int a=32767,b=a+1; //定义短整型无符号printf("a=%u\nb=%u\n",a,b);       //以无符号输出
}

结果

定义的时候a=32767,也就是0111 1111 1111 1111,输出的依然是32767,
a+1=32768, 二进制为1000 0000 0000 0000,输入依然为32768。
根据(3)中讲解的,无符号整型的二进制最高位为数据位,数据位为0为1都是按照正常来算的。

 

2.有符号整型((signed)int)

(1)int类型默认是有符号的,所以int实际上是signed int ,我们通常省略signed
(2)有符号整型也是32位。

(3)它的取值范围就与无符号整型不同了。它的范围是-2147483648~2147483647这个范围可以理解为无符号整型的一半变成了负数。

32位有点长,所以我们拿16位的short int 来举例。
short int 是16位的,有符号的范围是-32768~32767 ,二进制表示为:1000 0000 0000 0000 - 01111 1111 1111 1111

这个时候可能就有人发问了,32768用二进制表示为1000 0000 0000 0000,那么这个负的32768的负号又怎么理解呢?看下面
(4)举个例子;
还是以32767为例子,它的二进制为:0111 1111 1111 1111
对于有符号整型32767来说,它的二进制最高位称为符号位(而不是数据位了),符号位顾名思义就是决定正负号的,规则:0是正,1为负。
(5)列举一个程序理解(4)的内容

复制代码 代码如下:
#include <stdio.h>
main()
{short int a=32767,b,c,d;//定义无符号类型。b=a+1;c=a+2;d=a+3;printf("a=%d\nb=%d\nc=%d\nd=%d\n",a,b,c,d);
}

 

可以看出此时的结果竟然是这个样子的。为什么呢?怎么回事?
其实在计算机中,负数是并不存在的,它是以二进制补码的形式表示和存放。什么是补码呢?

(6)什么是补码,补码的运算。
我们还是列举一个简单的例子吧!就用-6.

我们经过以上的学习已经知道负数的符号位为1,所以:
 (1)-6的二进制: 1000 0000 0000 0110(称为原码,原码是计算机显示给我们的)
 (2)对原码求反码:1111 1111 1111 1001(称为反码,保持符号位不变,将原码中的0变1,1变0)
 (3)对反码加1:1111 1111 1111 1010(称为补码,补码是计算机中存储负数的形式)
在计算机中,如果存储的二进制是1111 1111 1111 1010,那么显示在我们前台的十进制数字就是-6。即:负数在计算机中是以该负数的二进制的补码形式存储的。

(7)了解了什么是补码后,再来看我们上述说的那个程序:
  32767的二进制为:0111 1111 1111 1111
我们来计算一下c的值为什么会等于-32767。
c=32767+2,c的二进制为:1000 0000 0000 0001(32767的二进制+2),c的这个二进制是在计算机中存储的补码,需要将它转换为原码,也就是将c的二进制数减一再取反。得到的二进制原码为:1111 1111 1111 1111。我们已经说过,符号位为1,表示负值,并不参加运算,所以此二进制的十进制为:-32767。
但是,上述中,c的原码的确是1111 1111 1111 1111,c在计算机中存储的补码也的确是1000 0000 0000 00010。但是-32767的由来却有另一种理解,c的补码是16位,32位编译器中有32位的二进制,也就是说在16位补码的前面还有(32-16=16)位的虚位数,并不属于计算机给short int分配的空间,但是这16位的位数当数表示正时为0,当数表示负数时为1。并且前16位的数字全部都与二进制倒数第8位的数字一致。也就是说:
  c 的补码是   1...1 1000 0000 0000 0010(1..1表示16个1)
我们可以这样计算:-2的7次方+2的1次方=-32767,这种理解普遍被大众所接受,而且避免了原码的概念。

(8)通过程序也可以发现一个规律,int的取值范围是-32768~32767,把头尾连接起来形成一个环就可以了。


http://chatgpt.dhexx.cn/article/VWWsMMvH.shtml

相关文章

unsigned int 与 int 间的区别

unsigned int 是无符号整型&#xff0c;要求定义的整数一定是正整数。 当把一个负数赋值给无符号整型的变量的时候&#xff0c;会自动把最高位的符号位看成整数的一部分。 例如&#xff1a; unsigned int a -10; printf("%u", a); 结果为 因为-10的在计算机中存…

#C语言# unsigned类型的用法!

笔者今天在刷题时&#xff0c;有一个测试点老是通不过&#xff0c;经过多次检查代码和查看大佬题解之后&#xff0c;发现是一个小细节出了问题。 测试点的正确输出是一个大正数&#xff0c;笔者的测试输出是一个负数&#xff0c;差的离谱。 我一开始用的是int型的变量进行累加…

c语言--unsigned修饰符

在C语言中&#xff0c;unsigned是一种无符号整数修饰符。它可以与多个整数类型&#xff08;如int、short、long等&#xff09;结合使用&#xff0c;表示该整数类型只包含非负数值。unsigned修饰的整数类型不保存正负号位&#xff0c;因此可以用来表示更大的正整数范围。 例如&…

unsigned详讲(干货满满)

前言&#xff1a;过年偷懒了(●ˇ∀ˇ●)&#xff0c;但是年后开学了一定要恢复学习状态&#xff0c;在复习加继续学习的途中&#xff0c;我发现对于unsigned关键字的掌握并不是很熟练&#xff0c;于是翻阅了各个大佬的博客以及书籍&#xff0c;总结了对于unsigned的一些知识点…

python情感分析中文_【python机器学习】中文情感分析

3月31日,3月最后的一天接到了腾讯HR终面,看着招聘官网变成已完成还有点小自豪呢python 而后百度搜了搜显示“已完成”是否是稳了,原来不是,好多最后被通知没被录取。。。。web 随缘吧~代码还要继续码,博客还要继续更,论文还要继续写。。。。。正则表达式 数据源app 公众号…

yes or no?基于词典的情感分析法

自更博以来第一次断更&#xff0c;现在先把文本分析的坑补上&#xff0c;这篇文章着重介绍情感分析的两种基本方法之一&#xff1a;基于词典的情感分析&#xff08;下篇讲基于监督的情感分析&#xff09;&#xff0c;建模环境为R。 目录 1 背景与目的1.1 情感分析的应用场景1.…

snownlp情感分析

之前写过一篇博客&#xff0c;豆瓣短评分析&#xff0c;当时是拿分类问题来做的&#xff0c;预测的是用户给电影打的星级&#xff0c;其实也可以用snownlp对短评做情感分析。 情感分析就是用一些方法和技术来识别和提取原素材中的情感色彩&#xff0c;本篇博文主要就是介绍如何…

java 情感分析_Alink中文情感分析示例(Java版本)

Alink是基于Flink的机器学习算法平台,欢迎访问Alink的github获取下载链接及更多信息。alibaba/Alink​github.com 也欢迎加入钉钉群进行交流。 情感分析是对带有情感色彩(褒义贬义/正向负向)的主观性文本进行分析,以确定该文本的观点、喜好、情感倾向。本文将针对顾客对酒店的…

情感分析教程

作者|Zijing Zhu 编译|VK 来源|Towards Datas Science 据估计,世界上80%的数据是非结构化的。因此,从非结构化数据中提取信息是数据分析的重要组成部分。 文本挖掘是从非结构化文本数据中获取有价值的信息的过程,情感分析是文本挖掘的应用之一。它使用自然语言处理和机器学…

python 情感分析实例_基于Python的情感分析案例

**情感分析 **又称为倾向性分析和意见挖掘 它是对带有情感色彩的主观性文本进行分析、处理、归纳和推理的过程 其中情感分析还可以细分为情感极性 倾向 分析 情感程度分析 主客观分析等。 情感极性分析的目的是对文本进行褒义、贬义、中性的判 **情感分析&#xff1a;**又称为倾…

情感分析 综述

情感分析或观点挖掘是对人们对产品、服务、组织、个人、问题、事件、话题及其属性的观点、情感、情绪、评价和态度的计算研究。该领域的开始和快速发展与社交媒体的发展相一致&#xff0c;如评论、论坛、博客、微博、推特和社交网络&#xff0c;因为这是人类历史上第一次拥有如…

windows无法启动print spooler服务 资源不足,无法完成该操作

WIN10系统下print spooler打印服务无法启动&#xff0c;提示错误“错误0x800706b9资源不足&#xff0c;无法完成该操作”&#xff0c;可以快速的解决方法。 最近有Win10用户反馈无法打印机&#xff0c;而在启动print spooler服务&#xff08;打印服务&#xff09;时遇到错误提示…

【vSphere故障案例】案例十二:资源不足,vSphere HA故障切换级别

【vSphere故障案例】案例十二&#xff1a;资源不足&#xff0c;vSphere HA故障切换级别 2013-04-17 12:16:51标签&#xff1a;vSphere ESXi HA故障原创作品&#xff0c;允许转载&#xff0c;转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任…

解决32位程序报“内存资源不足,无法处理此命令”问题

1、先点击此链接下载插件包&#xff1a;​​​​​​​​​​​​​​​​​​​​​让32位程序能申请到4GB内存方法-C#文档类资源-CSDN文库 2、将EditBin放到程序的根目录 3、 程序的启动项的生成事件里面添加命令行 cd ..\EditBin\x64 editbin /largeaddressaware …

idea启动项目报错内存资源不足的问题

尝试一下几种方式&#xff1a; 1&#xff0c;改变idea的heap参数大小至1500 2&#xff0c;IDEA启动参数配置 -Xms128m -Xmx3072m -XX:ReservedCodeCacheSize240m -XX:UseConcMarkSweepGC -XX:SoftRefLRUPolicyMSPerMB50 -ea -XX:CICompilerCount2 -Dsun.io.useCanonPrefixCac…

Vcenter 资源不足,无法满足XXX中集群 上的vSphere HA故障切换级别

故障现象: 做Vmotion时发现报错:Vcenter 资源不足,无法满足XXX中集群 上的vSphere HA故障切换级别 点开集群摘要发现,预留cpu和内存都是100%. 解决过程如下:

海康威视4200服务器显示资源不足,硬盘录像机提示“资源不足”是什么原因 -

很多人来问重庆监控&#xff0c;画面上会提示资源不足是怎么回事&#xff1f;重庆监控来给大家科普一下&#xff1a;资源不足不是设备的故障&#xff0c;他只是一种现象提示&#xff0c;画面上无图像&#xff0c;并且叠加了“资源不足”文字提示。有些伙伴可能重启了录像机几次…

资源优化问题常见形式

1 常见优化问题形式 1.1 以最大化多用户 的 和 速率的形式 此情况下&#xff0c;无论是该和速率是作为目标函数&#xff0c;还是作为约束&#xff0c;都不是凸函数的形式&#xff0c;原因是涉及到 log(.)log(.) 的形式&#xff0c;是非凸的。常见解决方法&#xff0c;是采用 …

不要再抱怨项目资源不足了,这么办都能解决

无论是企业还是银行&#xff0c;项目管理在组织中的地位越来越重要。但笔者走访了超过200家银行和超过100家大型企业&#xff0c;项目管理存在的问题依然严峻&#xff0c;在这些组织中项目管理的成熟度水平依然有较大的提升空间。 在项目管理的十大知识领域里面&#xff0c;资…

node资源不足导致的pod pending状态

背景 linux centos7.6系统 k8s集群刚刚经历节点资源缩容&#xff1a;从8C 32缩小至4c16G 现象 恢复k8s节点后发现很多pod都处于Pending : 原因 由于资源缩容&#xff0c;每个服务占用的cpu和内存值没有改变&#xff0c;导致机器分配资源时内存或cpu不足导致 这一点可以通过…