• 关于C语言中整数范围的一些解释


    示例代码

    #include <stdio.h>
    
    int main() {
        
        char c = 255;
        printf("%d
    ", c);
        int i = 255;
        printf("%d
    ", i);
    
        return 0;
    }

    输出结果

    -1
    255

    解释

      计算机是以二进制补码的形式存储数值。

      char 的大小是 1 个字节(8bit),取值范围是 -128 ~ 127。255 的二进制原码是 1111 1111,而 1111 1111 作为补码的值是 -1,所以 char c = 255 输出 -1。假设 char c = 257。257 的二进制是 (1)0000 0001,丢弃超出范围的高位 1,符位为 0 是正数,正数的补码是其本身,代码结果则输出 1。

      int 的大小是 4 个字节(32bit),取值范围是 -2^31 ~ 2^31 - 1,其范围值通常取决于编译器(CPU)。255 的二进制原码是 0000 0000 0000 0000 0000 0000 1111 11111,int 的取范围远远超过了 char 的取范围,所以 int i = 255 输出 255。

  • 相关阅读:
    DJANGO
    前端--BootStrap
    前端--JQuery
    前端--JavaScript
    前端--CSS
    前端--HTML
    python中面试题积累
    python中一些小的知识点
    python中字典的增删改查及相关知识点
    python中列表的增删改查以及其它相关方法
  • 原文地址:https://www.cnblogs.com/qpliang/p/11390238.html
Copyright © 2020-2023  润新知