根据C和C++ , CHAR_BIT >= 8.
但无论何时CHAR_BIT > 8,uint8_t甚至都不能表示为8位.
它必须更大,因为它CHAR_BIT是系统上任何数据类型的最小位数.
什么样的系统可以uint8_t合法地定义为除了以外的类型unsigned char?
(如果C和C++的答案不同,那么我想知道两者.)
现在我们有时必须使用二进制数据.在C++中,我们使用字节序列,因为开头char是我们的构建块.定义为sizeof1,它是字节.char默认情况下,所有库I/O函数都使用.一切都很好,但总是有一点担心,有点奇怪,一些人的错误 - 一个字节中的位数是实现定义的.
所以在C99中,决定引入几个typedef让开发人员轻松表达自己的固定宽度整数类型.当然可选,因为我们从不想伤害便携性.其中uint8_t,迁移到C++ 11中std::uint8_t,固定宽度的8位无符号整数类型,对于真正想要使用8位字节的人来说是完美的选择.
因此,开发人员接受了新工具并开始构建库,这些库明确表示它们接受8位字节序列std::uint8_t*,std::vector<std::uint8_t>或者其他方式.
但是,或许经过深思熟虑,标准化委员会决定不要求实施,std::char_traits<std::uint8_t>因此禁止开发人员轻松,便携地实例化,比如说,std::basic_fstream<std::uint8_t>并轻松读取std::uint8_t二进制数据.或许,我们中的一些人不关心字节中的位数并且对它感到满意.
但遗憾的是,两个世界相互冲突,有时您必须将数据作为char*并将其传递给期望的库std::uint8_t*.但是等等,你说,是不是char变量位并std::uint8_t固定为8?它会导致数据丢失吗?
嗯,这里有一个有趣的标准.的char定义为保持正好一个字节和字节是内存的最低可寻址的块,所以用比特宽度比的较小不能有一个类型char.接下来,它被定义为能够保存UTF-8代码单元.这给了我们最小--8位.所以现在我们有一个typedef,它要求是8位宽,并且是一个至少8位宽的类型.但有其他选择吗?是的,unsigned char.请记住,签名char是实现定义的.还有其他任何一种 谢天谢地,没有.所有其他整数类型都需要超出8位的范围.
最后,std::uint8_t是可选的,这意味着如果未定义使用此类型的库将无法编译.但如果它编译呢?我可以非常自信地说,这意味着我们在8位字节的平台上CHAR_BIT == 8.
一旦我们有这方面的知识,我们已经8位字节,这std::uint8_t是实现为char或者unsigned char,我们可以假设,我们可以做reinterpret_cast的char*到std::uint8_t*,反之亦然?它是便携式的吗?
这是我的Standardese阅读技巧让我失望的地方.我读了关于安全派生的指针([basic.stc.dynamic.safety]),据我所知,以下内容:
std::uint8_t* buffer = /* ... */ ;
char* buffer2 …Run Code Online (Sandbox Code Playgroud) 我正在尝试将一个[]uint8字节数组转换为一个float64GoLang.我无法在线找到此问题的解决方案.我已经看到过首先转换为字符串然后转换为a的建议float64但是这似乎不起作用,它失去了它的价值而我最终得到了零.
例:
metric.Value, _ = strconv.ParseFloat(string(column.Value), 64)
Run Code Online (Sandbox Code Playgroud)
它不起作用......
我有一个指向uint8类型向量的指针.
我如何获取此指针并将向量中的数据转换为代表其内容的完整字符串?
我有一个需要通过CAN协议发送的float变量.为此,必须在4个uint8_t变量中切割32位的浮点数.
我完全不知道该怎么做.我首先考虑将float转换为int但我在Internet上找到的使用强制转换或联合的一些答案似乎不起作用.
这是我正在尝试做的一个简单示例:
float f;
uint8_t ut1,ut2,ut3,ut4;
//8 first bits of f into ut1
//8 second bits of f in ut2
...
// Then I can send the uint8_t through CAN
...
Run Code Online (Sandbox Code Playgroud)
谢谢.
c++ casting type-conversion uint8t floating-point-conversion
我想在我的C模块中传递一个函数的参数uint8_t的数组.
我找不到直接解析这个数组的方法,所以我将它解析为PyObject_t然后迭代为PyTuple_t对象.这样,我需要将此元组的每个元素PyObject_t转换为uint8_t.
一旦没有PyInt_FromUINT8_t函数或类似函数,我怎么能这样做呢?
我是C-Headers的新手- stdint.h和inttypes.h。我正在尝试一些代码以了解uint8_t工作原理。但是,似乎遇到了问题。
我已经声明了4 uint8_t个分别具有边界值0、255、256,-1的整数,并对其执行了一些简单的算术运算。我这样做是因为我想知道C编译器(我在Linux上使用)会产生什么错误/警告gcc 5.4.0。如果不是这样的话,我很想知道输出是什么样子。下面给出的代码。
#include <inttypes.h>
#include <stdint.h>
#include <stdio.h>
int main() {
int a = 10;
printf("%d\n", a++);
printf("%d\n\n", a);
// 8 bit unsigned integer -> range[0, 255]
uint8_t ua81=0, ua82=255, ua83=256, ua84=-1;
printf("--------STDINT.H----uint8_t--DEMO--------\nua81 = %" PRIu8 "\n", ua81);
printf("ua82 = %" PRIu8 "\nua83 = %" PRIu8 "\nua84 = %" PRIu8 "\n\n", ua82, ua83, ua84);
printf("ua81+1 = %" PRIu8 "\nua82-3 = %" PRIu8 "\nua83-4+7 = %" PRIu8 …Run Code Online (Sandbox Code Playgroud) 这是一个将int值转换为的正确方法uint8_t:
int x = 3;
uint8_t y = (uint8_t) x;
Run Code Online (Sandbox Code Playgroud)
假设x永远不会小于0.虽然gcc没有给出上述行的任何警告,我只是想确定它是否正确或者是否有更好的方法将int转换为uint8_t?
PS如果你打算建议一个标准函数,我在Linux上使用C.
我正在用 C 进行编码,我知道可以存储在uint8_t0 到 255 范围内的值。我想存储一个 的百分比值MAX_INTENSITY,声明为:
#define MAX_INTENSITY 200
我可以执行以下操作吗:
uint8_t my_intensity = (MAX_INTENSITY * percentage) / 100;?
结果将是200 或更小,但在计算过程中,中间结果可以优于255,例如percentage = 50,MAX_INTENSITY * percentage= 10'000。即使最终结果是 100, o 在 a 范围内,这会导致问题吗uint8_t?
我有一个 uint8_t 类型的数组。我想创建一个字符串来连接数组的每个元素。这是我使用 ostringstream 的尝试,但之后字符串似乎为空。
std::string key = "";
std::ostringstream convert;
for (int a = 0; a < key_size_; a++) {
convert << key_arr[a]
key.append(convert.str());
}
cout << key << endl;
Run Code Online (Sandbox Code Playgroud)