源码 补码 反码

机器数:一个数在计算机中的二进制表示形式,  叫做这个数的机器数。机器数是带符号的,在计算机用一个数的最高位存放符号, 正数为0, 负数为1.

 

真值:第一位是符号位,将带符号位的机器数对应的真正数值称为机器数的真值。

 

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

 

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

 

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

          计算机内的所有值计算,均换成补码进行。

          为什么使用补码:

          (1)计算机辨别"符号位"显然会让计算机的基础电路设计变得十分复杂! 于是人们想出了将符号位也参与运算的方法。

                 负数的补码与对应正数的补码之间的转换可以用同一种方法——求补运算完成,可以简化硬件。可将减法变为加法,省去减法器。

                 无符号数及带符号数的加法运算可以用同一电路完成。

 

          (2)使用补码, 不仅仅修复了0的符号以及存在两个编码的问题, 而且还能够多表示一个最低数. 这就是为什么8位二进制, 使用原码或反码表示的范围为[-127, +127],

                而使用补码表示的范围为[-128, 127].

 

          (3)因为机器使用补码, 所以对于编程中常用到的32位int类型, 可以表示范围是: [-231, 231-1] 因为第一位表示的是符号位.而使用补码表示时又可以多保存一个最小值.

 

         补码的原理:使用了 “同余”的原理,即时钟往前拨(加法)和往回拨(减法),可以实现同样的计算结果。

 

 

signed 和 unsigned

 

c语言中,存在:

unsigned int /int

unsigned char /char

unsigned short /short

double (带符号的类型)

 

当一个无符号数和一个有符号数进行比较运算时,有符号数会被隐含的转换成无符号数,并假设这两个数都是非负数,然后进行比较运算。当把一个有符号数转换成无符号数时,其底层的二进制表示没有改变,仅仅是对其进行了不同的解释。

 

注意点:

(1) 当2个unsigned 的整数比较时,不能用相减判断,而是直接用 > 或 < 来判断

(2)位数小于int的提升到int,int之后都是从signed –> unsigned

(3)对于浮点数来说,浮点数(float,double)实际上都是有符号数,unsigned 和signed前缀不能加在float和double之上,当然就不存在有符号数根无符号数之间转化的问题了。

一定要记住如果需要使用有符号数时不要忘记强制转换。

 

  1. if( x2>x1)
  2. printf(" x2-x1>0 x1:%d x2:%d x2-x1:%d x2-x1:%u \n",x1,x2,x2-x1,x2-x1 );
  3. else
  4. printf("x2-x1<0 x1:%d x2:%d x2-x1:%d x2-x1:%u \n",x1,x2,x2-x1,x2-x1 );
  5.  
  6. if( (x2-x1) >0 )
  7. printf(" x2-x1>0 x1:%d x2:%d x2-x1:%d x2-x1:%u \n",x1,x2,x2-x1,x2-x1 );
  8. else
  9. printf("x2-x1<0 x1:%d x2:%d x2-x1:%d x2-x1:%u \n",x1,x2,x2-x1,x2-x1 );

运行结果

  1. x2-x1<0 x1:99 x2:88 x2-x1:-11 x2-x1:4294967285
  2. x2-x1>0 x1:99 x2:88 x2-x1:-11 x2-x1:4294967285

 

 

  1. int a = -1;
  2. unsigned int b = 1;
  3.  
  4. char x = -1;
  5. unsigned char y = 1;
  6.  
  7. int m = -1;
  8. unsigned char n = -1;
  9.  
  10. char t1 = -1;
  11. unsigned int t2 = -1;
  12.  
  13. printf("a>b :%d\n", a > b);
  14. printf("x>y :%d\n",x>y );
  15. printf("m>n :%d\n",m>n);
  16. printf("t1>t2: %d\n",t1>t2);

运行结果

  1. a>b :1 /* a,b转成 unsigned int */
  2. x>y :0 /* x,y 均被转成 int */
  3. m>n :0 /*原因在于要把n提升为int就是255当然大于-1了,unsigned char 先提升为int,送入int的低八位中,高位全部补零 . 位数少的类型往位数多的类型转换 、*/
  4. t1>t2: 0 /* t1转成 unsigned int 为0xffffffff,t2也是 0xffffffff ,比较应该是相等 */

 

 

 

 

参考

http://www.cnblogs.com/zhangziqiu/archive/2011/03/30/ComputerCode.html

c语言下的变量类型及计算的更多相关文章

  1. Java语言支持的变量类型有哪几种

    Java语言支持的变量类型有: 类变量:独立于方法之外的变量,用 static 修饰. 实例变量:独立于方法之外的变量,不过没有 static 修饰. 局部变量:类的方法中的变量. 实例: publi ...

  2. Java入门 - 语言基础 - 06.变量类型

    原文地址:http://www.work100.net/training/java-variable-type.html 更多教程:光束云 - 免费课程 变量类型 序号 文内章节 视频 1 概述 2 ...

  3. JS(面试中的变量类型和计算问题)

    JS(变量类型和计算) 题目1.JS 中使用 typeof 能得到那些类型? 题目2.何时使用 === 何时使用==? 题目3.JS 中有哪些内置函数? 题目4.JS 变量按照存储方式区分为那些类型, ...

  4. js变量类型和计算

    # js入门基础-变量类型和计算 ` --首先由于我使用了一个不太合格的markdown来编写来文章,所以在移动端阅读不要太方便,建议移动端使用横屏模式或pc端阅读,当然如果你有平板那是最好的. -- ...

  5. Java语言支持的变量类型有

    Java语言支持的变量类型有: 类变量:独立于方法之外的变量,用 static 修饰. 实例变量:独立于方法之外的变量,不过没有 static 修饰. 局部变量:类的方法中的变量.

  6. js面试题知识点全解(一变量类型和计算)

    1.js中使用typeof能得到哪些类型 2.何时使用===和== 3.js中的内置函数 4.js变量按存储方式区分为哪些类型,并描述其特点 5.如何理解json 以下对这些问题的知识点做一些总结: ...

  7. JS变量类型与计算

    一.题目 1.JS中使用typeof能得到哪些类型? 2.何时使用===何时使用==? 3.JS中有哪些内置函数? 4.JS变量按照存储方式区分为哪些类型,并描述其特点? 5.如何理解JSON? 知识 ...

  8. JS基础知识——变量类型和计算(一)

    JS中使用typeof能得到的哪些类型? 何时使用===何时使用==? JS中有哪些内置函数? JS变量按照存储方式区分为哪些类型,描述其特点? 如何理解JSON? 知识点梳理 一.变量类型: (1) ...

  9. go语言中获取变量类型的三种方法

    package main import ( "fmt" "reflect" ) func main() { var num float64 = 3.14 // ...

随机推荐

  1. FreeRADIUS + MySQL 安装配置笔记

    FreeRADIUS + MySQL 安装配置笔记 https://www.2cto.com/net/201110/106597.html

  2. java8新特性视频、spring4.0视频讲解,javaee基础知识讲解等网址汇总

    1.http://ke.atguigu.com/     海量视频首页 2.http://ke.atguigu.com/course/56    java8新特性学习地址

  3. Makefile系列之五 :函数

    一.函数的调用语法 函数调用与变量一样,也是以“$”来标识的,其语法如下: $(<function> <arguments>) 或是 ${<function> &l ...

  4. Android Studio代码字体模糊解决方法

    问题描述: 我的电脑分辨率是(1920*1080),然而安装了Android Studio后代码的一些部分区域出现模糊的现象,应该是软件默认设置与高分屏有冲突. 如下图所示. 解决方法: 打开设置对话 ...

  5. TCP Socket Port Check

    写了两个小程序,主要是用于linux和windows下TCP端口的检测,自带的telnet无法满足我批量检测的需要,在我眼里这类端口检测程序最为关键的是超时的限制,若端口不能却要老久才返回结果,有点不 ...

  6. SGU 261. Discrete Roots

    给定\(p, k, A\),满足\(k, p\)是质数,求 \[x^k \equiv A \mod p\] 不会... upd:3:29 两边取指标,是求 \[k\text{ind}_x\equiv ...

  7. rpm包管理和源码包管理

    (1)软件类型 源码包 需要gcc编译 nginx-1.12.1.tar.gz 二进制包 已编译 mysql-community-common-5.7.12-1.el7.x86_64.rpm 常见的二 ...

  8. Interllij IDEA 注释模板(类和方法)

    类上的注释: file->setting->Editor->Filr and Code Templates->Includes->File Header /** * @A ...

  9. php中网页生成图片的方式

    在网上找了很多方法,发现与自己最初的思路也是大同小异,那就是HTML——>PDF——>JPG.从上午9点钟一直搞到下午6点钟,代码方面其实很简单,更多的还是环境和PHP拓展上面,忙了一天的 ...

  10. 杀掉lampp进程

    #!/bin/sh pid='ps -ef|grep lampp|grep -v grep|awk '{ print $2 }'' echo $pid exit if[ $pid ] then for ...