之前说到了long的争议(http://www.cnblogs.com/dotnetcrazy/p/8059210.html),这边就不用long来举例了,用int吧

可以看一下这篇文章(http://www.cnblogs.com/dotnetcrazy/p/6743530.html),更好理解本文(本文不继续探讨大小端对齐问题,只研究标题内容)

1.基础就不详解了贴张图

说一下QWORD,之前也被网上误导了,网上很多都是说无符号的word,按照惯例,如果是unsigned word,那么所占字节应该和word一样才对

验证:有无符号,他所占字节并不变

后来发现Win10最新版有一计算器神器(你们可以通过应用商城装)===》

通过7来说说这些“字”宝宝们(我后面说补码计算的时候也会用到这个案例)

1Byte=8bit(一个二进制位就是一个bit)

7==》0000 0111

1WORD=2Byte,7==》0000 0000 0000 0111

1DWORD=4Byte,7==》0000 0000 0000 0000 0000 0000 0000 0111

重点来了,要是QWORD真的是WORD无符号字,那么应该和WORD一样只占2Byte

然而事实==》打脸打的PaPa响,1QWORD=8Byte,7==》以下省略一千字

2.原码,反码,补码

在计算机内,有符号数有3种表示法:原码、反码和补码

原码:计算机中对数字的二进制定点表示方法。最高位为符号位(正数该位为0,负数该位为1)其余位表示数值的大小

反码:正数的反码与其原码相同,负数的反码:符号位不动,其他取反

补码:正数的补码和原码相同,负数的补码:符号位不动,其他取反,最后+1(相当于:补码+1

补码的好处:使符号位能与有效值部分一起参加运算,从而简化运算规则;使符号位能与有效值部分一起参加运算,从而简化运算规则

来张图更直观

来来来,实践验证一下:

分析:按照求负数补码的逆过程,数值部分应是最低位减1,然后取反。
但是对二进制数来说,先减1后取反和先取反后加1得到的结果是一样的,故仍可采用取反加1 的方法。

这些都比较简单,下面说下补码的好处

体验分析一下

7-6=1;-7+6=-1

7-6=1

7补码:0000 0111

-6补码:1111 1010

  0000 0111
1111 1010
---------
1 0000 0001

进位舍弃(总共就8位,溢出就没了),0000 0001==>1(正数的补码是他本身)

-7+6=-1

-7补码:1111 1001

6补码:0000 0110

1111 1001
0000 0110
---------
1111 1111

木有进位,补码:1111 1111,正码(符号位不动,其他取反,最后+1):1000 0001==>-1

扩展(有兴趣的可以自己研究一下补码的各种溢出):https://baike.baidu.com/item/反码#5

3.整数溢出探讨

 intmax=0x7FFFFFFF; (2147483647)

不清楚的可以看这个图,第一位是符号位,后面是数值部分,所以第一个最大是7,其他最大是F

借用Net里面的Int.Max验证下:2147483647

不高兴搞需的,毕竟不是学生了,直接跑个程序看看

int main() {
int i = 0x7fffffff;
printf("i=%X==>%d\n", i, i);
i += 1;
printf("i+1=%d==>%X\n", i, i);
return 0;
}

CentOS_X64:i+1=-2147483648==>0x80000000

Win10_X64:i+1=-2147483648==>0x80000000

记得以前学生时代就很不解,老师也说不清楚,这次看见了就研究了下

来来来,Net来个福利:自己研究下为啥

不扯了,二进制走一个:(二进制是不管符号位啥的,输出的八进制和十六进制其实都是unsigned int (%o,%x))

0111 1111 1111 1111  1111 1111 1111 1111
+1
1000 0000 0000 0000 0000 0000 0000 0000
———— ———— ———— ———— ———— ———— ———— ————
8 0 0 0 0 0 0 0

intmax+1=0x80000000,程序员还是比较喜欢十六进制啊~方便

可能你还没转过来,(⊙o⊙)…,好吧,我们用补码的方式再算一遍

0111 1111 1111 1111  1111 1111 1111 1111
0000 0000 0000 0000 0000 0000 0000 0001
---- ---- ---- ---- ---- ---- ---- ----
1000 0000 0000 0000 0000 0000 0000 0000

转为正码:
1000 0000 0000 0000 0000 0000 0000 0000 补码
1111 1111 1111 1111 1111 1111 1111 1111 正码

2^31==>2147483648,符号位是1,则最后结果是-2147483648

------------------------------------------

收工了,感兴趣的可以用Win10计算神器看看(用QWORD又是怎样呢,可以自己思考,很有意思哦

稍微解释一下:word是2Byte,intmax是4Byte,所以不够放

在选下HEX,输入运算得到的数字

CPP--正码,反码,补码~附整数溢出的探讨的更多相关文章

  1. Java中正负数的存储方式-正码 反码和补码

    Java中正负数的存储方式-正码 反码和补码 正码 我们以int 为例,一个int占用4个byte,32bits 0 存在内存上为 00000000 00000000 00000000 0000000 ...

  2. 原码 & 反码 & 补码 & 详解

    本篇文章讲解了计算机的原码, 反码和补码. 并且进行了深入探求了为何要使用反码和补码, 以及更进一步的论证了为何可以用反码, 补码的加法计算原码的减法. 论证部分如有不对的地方请各位牛人帮忙指正! 希 ...

  3. C语言原码反码补码与位运算.

      目录:     一.机器数和真值     二.原码,反码和补码的基础概念     三.为什么要使用原码,反码和补码     四.原码,补码,反码再深入     五.数据溢出测试     六.位运算 ...

  4. Java基础-原码反码补码

    Java基础-原码反码补码 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 注意,我们这里举列的原码和反码只是为了求负数的补码,在计算机中没有原码,反码的存在,只有补码. 一.原码 ...

  5. Java 原码 反码 补码

    本篇文章讲解了计算机的原码, 反码和补码. 并且进行了深入探求了为何要使用反码和补码, 以及更进一步的论证了为何可以用反码, 补码的加法计算原码的减法. 论证部分如有不对的地方请各位牛人帮忙指正! 希 ...

  6. 「C语言」原码反码补码与位运算

    尽管能查到各种文献,亲自归纳出自己的体系还是更能加深对该知识的理解.     本篇文章便是在结合百度百科有关原码.反码.补码和位运算的介绍并深度借鉴了张子秋和Liquor相关文章后整理而出.   目录 ...

  7. 位移&二进制转换&原码&反码&补码

    << 左移 按二进制形式把所有的数字向左移动对应的位数,高位移出(舍弃),低位的空位补零. 格式 需要移位的数字 << 移位的次数 计算过程 1. 按二进制形式把所有的数字向左 ...

  8. python之计算机硬件基本认知_数据单位_进制间转换_数的原码反码补码

    一:计算机硬件基本认知 cpu:   中央处理器.   相当于人的大脑.运算中心,控制中心. 内存:  临时存储数据. 优点:读取速度快,缺点:容量小,造价高,断电即消失. 硬盘:  长期存储数据. ...

  9. C 标识符, 数据存储形式(原码,反码,补码)

    一.  标识符 第一个字母必须是英文字母或下划线 二. 数据存储形式(补码存储) 最高位是符号位 ---- 0表示整数 ; 1 表示负数 1. 正数:原码 = 反码 = 补码 例子 : (10) 原码 ...

随机推荐

  1. codeforces 895A Pizza Separation 枚举

    codeforces 895A Pizza Separation 题目大意: 分成两大部分,使得这两部分的差值最小(注意是圆形,首尾相连) 思路: 分割出来的部分是连续的,开二倍枚举. 注意不要看成0 ...

  2. POJ1273 网络流-->最大流-->模板级别-->最大流常用算法总结

    一般预流推进算法: 算法思想: 对容量网络G 的一个预流f,如果存在活跃顶点,则说明该预流不是可行流. 预流推进算法就是要选择活跃顶点,并通过它把一定的流量推进到它的邻接顶点,尽可能将正的赢余减少为0 ...

  3. Vue单页面骨架屏实践

    github 地址: VV-UI/VV-UI 演示地址: vv-ui 文档地址:skeleton 关于骨架屏介绍 骨架屏的作用主要是在网络请求较慢时,提供基础占位,当数据加载完成,恢复数据展示.这样给 ...

  4. VS2015 密钥key

    亲测可用: HMGNV-WCYXV-X7G9W-YCX63-B98R2

  5. 大白话Vue源码系列(01):万事开头难

    阅读目录 Vue 的源码目录结构 预备知识 先捡软的捏 Angular 是 Google 亲儿子,React 是 Facebook 小正太,那咱为啥偏偏选择了 Vue 下手,一句话,Vue 是咱见过的 ...

  6. Codeforces 821E Okabe and El Psy Kongroo

    题意:我们现在位于(0,0)处,目标是走到(K,0)处.每一次我们都可以从(x,y)走到(x+1,y-1)或者(x+1,y)或者(x+1,y+1)三个位子之一.现在一共有N段线段,每条线段都是平行于X ...

  7. CEF中JavaScript与C++交互

    在CEF里,JS和Native(C/C++)代码能够非常方便的交互,这里https://bitbucket.org/chromiumembedded/cef/wiki/JavaScriptIntegr ...

  8. 假设不小心改动了系统SDK文件,编译无法通过改怎么办?(iOS开发)

     project报例如以下错误: fatal error: file '/Applications/Xcode.app/Contents/Developer/Platforms/iPhoneSimul ...

  9. Struts2学习笔记整理(二)

    这里是重点. Action接口 struts2 的Action可以是POJO 为了让用户开发的Action更加规范struts2提供了一个Action接口 ActionSupport基类 Struts ...

  10. 前端优化之动画为什么要尽量用css3代替js

    导致JavaScript效率低的两大原因:操作DOM和使用页面动画.通常我们会通过频繁的操作 DOM的CSS来实现视觉上的动画效果,导致js效率低的两个因素都包括在内了在频繁的操作DOM和CSS时,浏 ...