目录

一、补码

二、负数时的有符号整型和无符号整型的转换

三、关于无符号的笔试题

一、补码

有符号数在计算机中存储,用数的最高位存放符号, 正数为0, 负数为1

例如:有符号数 1000 0011,其最高位1代表负,其真正数值是 -3,而不是形式值131(无符号数1000 0011转换成十进制等于131)

原码:

原码就是符号位加上真值的绝对值,即用第一个二进制位表示符号(正数该位为0,负数该位为1),其余位表示值。

反码:

正数的反码与其原码相同;

负数的反码是对其原码逐位取反,但符号位除外。

补码:

正数的补码就是其本身;

负数的补码是在其反码的基础上+1

例如:

[+1] = [0000 0001]原 = [0000 0001]反 = [0000 0001]补

[-1] = [1000 0001]原 = [1111 1110]反 = [1111 1111]补

二、负数时的有符号整型和无符号整型的转换

当执行一个运算时(如这里的a>b),如果它的一个运算数是有符号的而另一个数是无符号的,那么C语言会隐式地将有符号 参数强制类型为无符号数,并假设这两个数都是非负的,来执行这个运算。

我们知道,整数在计算机中通常是以补码的形式存在的,而-1的补码(用4个字节储存)为1111,1111,1111,1111。而C语言对于强制类型转换是怎么处理的呢?对大多数C语言的实现,处理同样字长的有符号数和无符号数之间的相互转换的一般规则是:数值可能会改变,但是位模式不变。也就是说,将unsigned int强制类型转换成int,或将int转换成unsigned int底层的位表示保持不变。

也就是说,即使是-1转换成unsigned int之后,它在内存中的表示还是没有改变,即1111,1111,1111,1111。我们知道在计算机的底层,数据是没有类型可言的,所有的数据非0即1。数据类型只有在高层的应用程序才有意义,也就是说,同样的储存表示对于应用程序而言可能对应着不同的数据,例如1111,1111,1111,1111对于有符号数而言它表示-1,但对于无符号数而言,它表示UMax(因为没有符号位,就像正数的反码补码都是它本身一样,1111,1111,1111,1111的原码依然是它本身,且最高位也不表示符号位),但是它们的底层存储都是一样的。现在你应该明白为什么-1转换成无符号数之后,就成了UMax了吧。

unsigned int b = -1;

printf("%d\n", b);

printf("%u\n", b);

输出结果:

三、关于无符号的笔试题

以下反向遍历array数组的方法有什么错误?

vector array;

array.push_back(1);

array.push_back(2);

array.push_back(3);

//方向遍历array数组

for(vector::size_type i = array.size()-1; i>0; --i)

{

cout<

1)vectorarray;

2)vectorsize_type

3)首先for循环应该是i>=0,但是:

vector::size_type被定义为unsigned int,即无符号数,这样做为循环变量的i为0时再减1就会变成最大的整数,导致循环失去控制。

参考:

1.https://www.jianshu.com/p/3004e5999be4 你真的了解补码吗?

2.https://blog.csdn.net/ljianhui/article/details/10367703 都是类型惹的祸——小心unsigned

3.https://blog.csdn.net/qq_36767247/article/details/78444744 浅析无符号整型和有符号整型

4.http://c.biancheng.net/view/1332.html c++数据溢出

C语言中无符号整型变量赋值负数,负数时的有符号整型和无符号整型的转换相关推荐

  1. 负数时的有符号整型和无符号整型的转换

    目录 一.补码 二.负数时的有符号整型和无符号整型的转换 三.关于无符号的笔试题 一.补码 有符号数在计算机中存储,用数的最高位存放符号, 正数为0, 负数为1 例如:有符号数 1000 0011,其 ...

  2. C语言有符号整型和无符号整型的比较

    int s = -1; unsigned int u = 1; if(s < u) 这样比较的结果是:s>u,即出现-1>1 因为:在有符号整型和无符号整型的比较中,自动将有符号整型 ...

  3. C语言 有符号整型和无符号整型的比较

    C语言 有符号整型和无符号整型比较时,有符号整型自动转换成无符号整型,所以 10<-100 注意题给整数的范围,判断比较的整数类型

  4. C++有符号整型和无符号整型的区别

    C++有符号整型和无符号整型的区别 C++中的整型分为有符号类型整型和无符号类型整型,区别如下. 在有符号类型中:最左边的位是符号位,余下的位是数值位.符号位为1,代表负数:符号位为0,则为正数.例如 ...

  5. 有符号整型和无符号整型

    有符号整型和无符号整型的区别在于怎样解释整数的最高位 对于无符号整型,其最高位被c编译器解释为数据位 对于有符号整型最高位解释为符号位 如果符号位为0则表示为正数 为1则表示为负数 对于具有相同数据位 ...

  6. java发送c语言结构体_C语言中结构体直接赋值?

    在C语言中结构体变量之间可以进行赋值操作吗? 简单结构体的赋值 先说结论:一般来说,C语言中的结构体变量可以用另一个变量对其进行赋值或初始化.简单结构体(不包含指针成员)直接赋值没有问题. 我们先下面 ...

  7. c语言中数组部分输入赋值,c语言scanf对数组赋值

    c语言动态数组赋值,,c语言结构体数组赋值,c语言scanf对数组赋值 c语言数组动态赋值,<手把手教你学51单片机-C语言>之六 中断与数码管动态显示,c语言结构体数组赋值,c语言sca ...

  8. C语言中结构体直接赋值

    FROM:http://codewenda.com/c语言结构体直接赋值/ 在C语言中结构体变量之间可以进行赋值操作吗? 简单结构体的赋值 先说结论:一般来说,C语言中的结构体变量可以用另一个变量对其 ...

  9. c语言中不能将字符串赋值给字符数组

    参考文章:c语言中,为什么字符串可以赋值给字符指针变量 1.可以将字符串赋值给指向字符的指针p,而不能将字符串赋值给一个字符数组. char a[10]="hello";//正确的 ...

最新文章

  1. 打成jar包_keras, tensorflow模型部署通过jar包部署到spark环境攻略
  2. 关于VM热备份的三种方法
  3. AI开发者大会:2020年7月3日09:50--10:10唐杰《人工智能的下一个十年》
  4. 如果我要....(生活版)
  5. SAP Cloud SDK‘s Virtual Data Model
  6. Linux I/O 调度方法
  7. themyleaf 图片上传_javaEE --springboot #实现图片上传和回显 #单文件上传 #多文件上传 #ajax异步文件上传 (非常详细,从创建项目开始)...
  8. threadgroup_Java ThreadGroup list()方法与示例
  9. 【进阶技术】一篇文章搞掂:OAuth2
  10. 重新想象 Windows 8.1 Store Apps (91) - 后台任务的新特性: 下载和上传的新特性, 程序启动前预下载网络资源, 后台任务的其它新特性...
  11. Redis教程:数据对象分析(二)
  12. sql server需要存储1000万条数据该怎么办?
  13. 工业电气自动化及电工电子技能考核实训平台(高级版)
  14. 爬取包图网教师节海报
  15. c语言高级成分,高级语言的基本成分数据成分,运算成分,控制成分,传输成分,怎么看它们的类型区别的?比如其中对处理对象的类型说明属于高级语...
  16. Training data-efficient image transformers distillation through attention
  17. 学会自我管理有哪些好处?自我管理包括哪些内容?
  18. 51单片机 11.0592MHz 产生115200 波特率
  19. 聊聊如何才能学好编程
  20. 盘点全球最热十家大数据公司中国占三席

热门文章

  1. 考研英语 长难句训练day58
  2. inventor2014出现inventor应用程序错误0xc0000142
  3. 这才知道我的全部努力,不过完成了普通的生活。
  4. ffmpeg screen-capture-recorder快速安装
  5. EventManager
  6. 易语言取c盘文件夹中的文件被占用,易语言检测文件被哪个进程占用的代码
  7. Android8.0安装apk报错:Package xxx is currently frozen
  8. 央行发文深入推进农村支付服务环境建设并答记者问
  9. 用Matlab对图像进行ROI的标记与保存
  10. 笨笨对面向对象的理解