详解原码、反码与补码存储与巨细
发布时间:2021-01-10 11:26:08 所属栏目:创业 来源:网络整理
导读:详解原码、反码与补码存储与巨细 原码: 假如呆板字长为N个bit,那么一个数的原码就是N位二进制数,最高位 是标记位,1代表负数,0代表正数。 反码: 正数的反码就是原码,负数的反码就是标记位稳固,其他取反。 补码: 正数的补码与其原码沟通;负数的补码是
详解原码、反码与补码存储与巨细 原码: 假如呆板字长为N个bit,那么一个数的原码就是N位二进制数,最高位 反码: 正数的反码就是原码,负数的反码就是标记位稳固,其他取反。 补码: 正数的补码与其原码沟通;负数的补码是在其反码的末位加1。 char为1个字节,8个bit位,看看内存中是怎么存储的 十六进制 二进制(补码) 反码 原码 现实值 char a = 127; //7f 0111 1111 127 char b = 128; //80 1000 0000 0111 1111 1000 0000 -128 char c = -128; //80 1000 0000 0111 1111 1000 0000 -128 char d = -1; //ff 1111 1111 1111 1110 1000 0001 -1 -128也许各人会有疑问,1000 0000是负数,按补码反码原码的方法往回推减一为0111 1111,取反1000 0000为128,由于是负数以是就是-128. 以是signed char的最大值为127,最小值为-128. unsigned是无标记的意思,就是没有标记位。 unsigned char e = 256; //00 0000 0000 0 unsigned char f = -1; //ff 1111 1111 255 unsigned char g = 255; //ff 1111 1111 255 由于没有标记位,以是原反补码都一样,为什么-1的值为255呢,-1的原码是0000 0001(没标记位),反码1111 1110,补码 感激阅读,但愿能辅佐到各人,感谢各人对本站的支持! (编辑:湖南网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |