c++ - 256如何存储在char变量和unsigned char中

标签 c++ c memory char bit

最多255,我能理解整数是如何存储在charunsigned char中的;

#include<stdio.h>
int main()
{
        unsigned char a = 256;
        printf("%d\n",a);
        return(0);
}

在上面的代码中,我为 unsigned charchar 输出了 0

对于256,我认为这是整数在代码中的存储方式(这只是一个猜测):

首先256转换为二进制表示为100000000(共9位)。

然后他们删除了最左边的位(已设置的位),因为 char 数据类型只有 8 位内存。

所以它在内存中存储为 00000000 ,这就是它打印 0 作为输出的原因。

猜测是否正确或有其他解释?

最佳答案

你的猜测是正确的。转换为无符号类型使用模运算:如果值超出范围(太大或为负),则将其取模 2N 进行缩减,其中 N 是目标类型中的位数.因此,如果(通常情况下)char 有 8 位,则该值以 256 为模减少,因此 256 变为零。

请注意,转换为有符号类型没有这样的规则 - 超出范围的值会给出实现定义的结果。另请注意,char 未指定为恰好 8 位,并且在不太主流的平台上可以更大。

关于c++ - 256如何存储在char变量和unsigned char中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21530358/

相关文章:

c - 是否有 C 函数来获取文件的权限?

c - 我的结果是 1 但我输入的字符串长度更长

python - 在处理 python 列表分配时最小化内存消耗

c - 为启动时运行的 linux 内核添加代码

C++ 要求模板变量数量小于 N,但失败

c++ - 默认的 TIFF 方向是什么?

c++ - 带有指向自身的指针的 forward_list 结构

c - 如何从 C 中的二维数组中读取多个文件

c++ - OpenCV matchTemplate 抛出内存错误但只是第一次

c - 结构的内存大小不同?