关于C语言中整数范围的一些解释
发布时间:2020-12-14 05:09:16 所属栏目:大数据 来源:网络整理
导读:示例代码 #include stdio.h int main() { char c = 255 ; printf( " %dn " ,c); int i = 255 ; printf( " %dn " ,i); return 0 ;} ? 输出结果 - 1 255 ? 解释 计算机是以二进制补码的形式存储数值。 char 的大小是 1 个字节(8bit),取值范围是 -128 ~ 127
示例代码
#include <stdio.h> int main() { char c = 255; printf("%dn",c); int i = 255; printf("%dn",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 22222,int 的取范围远远超过了 char 的取范围,所以 int i = 255 输出 1。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |