gpt4 book ai didi

c++ - 字节缓冲区应该是有符号缓冲区还是无符号字符缓冲区?

转载 作者:IT老高 更新时间:2023-10-28 13:58:45 26 4
gpt4 key购买 nike

字节缓冲区应该是有符号字符还是无符号字符,或者只是一个字符缓冲区?C 和 C++ 有什么区别?

谢谢。

最佳答案

如果你打算存储任意二进制数据,你应该使用unsigned char。它是 C 标准保证没有填充位的唯一数据类型。每种其他数据类型都可能在其对象表示中包含填充位(即包含对象的所有位,而不是仅包含确定值的位)。填充位的状态未指定,不用于存储值。因此,如果您使用 char 读取一些二进制数据,事情将被缩减到 char 的值范围(通过仅解释值位),但可能仍然有一些位被忽略但仍然在那里并由 memcpy 读取。很像真实结构对象中的填充位。 unsigned char 类型保证不包含这些。这来自 5.2.4.2.1/2(此处为 C99 TC2,n1124):

If the value of an object of type char is treated as a signed integer when used in an expression, the value of CHAR_MIN shall be the same as that of SCHAR_MIN and the value of CHAR_MAX shall be the same as that of SCHAR_MAX. Otherwise, the value of CHAR_MIN shall be 0 and the value of CHAR_MAX shall be the same as that of UCHAR_MAX. The value UCHAR_MAX shall equal 2^CHAR_BIT − 1

从最后一句话可以看出,没有任何空间可供任何填充位使用。如果您使用 char 作为缓冲区的类型,您还会遇到溢出问题:将任何值明确分配给 8 位范围内的一个此类元素 -所以你可能期望这样的赋值是可以的——但不在 char 的范围内,即 CHAR_MIN..CHAR_MAX,这样的转换溢出并导致实现定义的结果,包括信号的引发。

即使与上述有关的任何问题可能不会在实际实现中显示(将是非常质量很差的实现),您最好从一开始就使用正确的类型,即无符号字符

然而,对于字符串,选择的数据类型是 char,字符串和打印函数可以理解它。出于这些目的使用 signed char 对我来说似乎是一个错误的决定。

更多信息,请阅读 this proposal其中包含对下一版本 C 标准的修复,最终将要求 signed char 也没有任何填充位。它已被纳入 working paper .

关于c++ - 字节缓冲区应该是有符号缓冲区还是无符号字符缓冲区?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/653336/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com