Fork me on github

原码补码反码 - 简介

原码:

  原码就是符号位加上真值的绝对值, 即用第一位表示符号, 其余位表示值. 比如如果是8位二进制:

  [+1] = 0000 0001

  [-1] = 1000 0001

  第一位是符号位. 因为第一位是符号位, 所以8位二进制数的取值范围就是:

  [1111 1111 , 0111 1111]

  即:[-127 , 127]

反码:

  反码的表示方法是:

  正数的反码是其本身

  负数的反码是在其原码的基础上, 符号位不变,其余各个位取反.

  [+1] = [00000001] = [00000001]

  [-1] = [10000001] = [11111110]

补码:

  补码的表示方法是:

  正数的补码就是其本身

  负数的补码是在其原码的基础上, 符号位不变, 其余各位取反, 最后+1. (即在反码的基础上+1)

  [+1] = [00000001] = [00000001] = [00000001]

  [-1] = [10000001] = [11111110] = [11111111]

posted @ 2016-09-24 13:53  未配妥剑,已入江湖  阅读(247)  评论(0编辑  收藏  举报