设为首页 加入收藏

TOP

关于C语言中整数范围的一些解释
2019-09-03 02:42:28 】 浏览:28
Tags:关于 言中 整数 范围 一些 解释

示例代码

#include <stdio.h>

int main() {
    
    char c = 255;
    printf("%d\n", c);
    int i = 255;
    printf("%d\n", 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^32 ~ 2^32 - 1,其范围值通常取决于编译器(CPU)。255 的二进制原码是 0000 0000 0000 0000 0000 0000 1111 11111,int 的取范围远远超过了 char 的取范围,所以 int i = 255 输出 255。


关于C语言中整数范围的一些解释 https://www.cppentry.com/bencandy.php?fid=45&id=246516

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇STM32F4 阿波罗寄存器点亮LED灯 下一篇C语言编程入门之--第五章C语言基..