zoukankan      html  css  js  c++  java
  • short int 变量的取值范围

    为什么 C 语言中 short int (若为16位)变量的取值范围是 -32768 ~ 32767 ??? 而并不是 -32767 ~ 32767.

    1. 最高位为符号位;最高位为0表示正数,最高位为1表示负数;

    2. 若以原码表示,16位二进制原码最大为 0111 1111 1111 1111 = 215 - 1 = 32767, 最小为 1111 1111 1111 1111 = -(215 - 1) = -32767, 0 有两种表示方法,即正0 (0000 0000 0000 0000)和负0 (1000 0000 0000 0000);

    3. 计算机中采用二进制补码存储数据;其中正数的补码 = 原码,负数的补码 = 反码 + 1;

    4. 若以反码表示,16位二进制范围

      正数: 0000 0000 0000 0001 ~ 0111 1111 1111 1111 (1 ~ 32767) 

        正 0: 0000 0000 0000 0000

        负 0: 原码 1000 0000 0000 0000, 补码 1111 1111 1111 1111 + 0000 0000 0000 0001 = (1) 0000 0000 0000 0000

        负数: 

                  原码:1111 1111 1111 1111 (-32767),补码:1000 0000 0000 0000 + 0000 0000 0000 0001 = 1000 0000 0000 0001

         原码:1000 0000 0000 0001 (-1),       补码:1111 1111 1111 1110 + 0000 0000 0000 0001 = 1111 1111 1111 1111

     请注意,再以补码表示的16位二进制数中,0表示为 0000 0000 0000 0000,正数范围为 (0000 0000 0000 0001 ~ 0111 1111 1111 1111),负数范围为 (1000 0000 0000 0001 ~ 1111 1111 1111 1111);其中还有一个补码 1000 0000 0000 0000尚未用到,于是人为的将这个补码定义为实际中的数字 -32768.

  • 相关阅读:
    关于:HTTP Header -> Content-Type: text/plain Cache-Control: no-cache IE浏览器弹出错误下载对话
    Linux 基础入门
    Java 并发——多线程基础
    JavaScript面向对象
    理解JavaScript的定时器与回调机制
    理解领域模型
    邮件协议基础知识
    Java NIO 学习笔记
    Java Socket 学习笔记
    HTTP协议基础与实验
  • 原文地址:https://www.cnblogs.com/lh03061238/p/15201276.html
Copyright © 2011-2022 走看看