在 c++ 中将双精度转换为 8 长度的字符数组
Convert double to 8 length char array in c++
我想在 c++ 中将双精度数组转换为 8 长度的字符数组。问题是我想涵盖双精度类型的所有字节数(双精度在 c++ 中并不总是 8 字节长)。
char数组仅用于存储双精度的字节,就好像 char type = 字节类型一样。
有什么想法吗?
是的,您始终可以将任何对象视为字节数组。要访问字节,请使用重新解释转换:
T x; // any object
unsigned char const * bytes = reinterpret_cast<unsigned char const *>)(&x);
for (std::size_t i = 0; i != sizeof(T); ++i)
{
std::fprintf("Byte %zu is %02Xn", bytes[i]); // assuming CHAR_BIT == 8
}
请注意,通常没有办法知道哪些字节是对象表示的一部分以及它们的实际含义是什么。例如,long double
在某些平台上可能具有 12 或 16 的大小,但只有 10 个相关字节,您不知道哪个是哪个。尽管对于大小为 8 的double
,可以合理地假设没有填充,并且字节以线性顺序构成 IEEE-754 表示形式。您的平台手册可能会告诉您。
相关文章:
- 指向指向字符数组的指针数组的指针
- 比较字符数组
- 如何使用Crypto++并为RSA返回可打印的字节/字符数组
- 使用无符号字符数组有效存储内存
- 错误:字符数组的初始值设定项太多
- 对字符数组中的元素执行逐位操作
- C++ 无法在字符数组中使用 for 循环打印字母模式
- 如何在 C++ 中从文件中读取字符数组(带有一些空格)
- C++ 传递二维字符数组
- 无法在 C++ 中输入字符数组
- 字符数组中的元素数
- 我的目标是编写一个程序来计算和存储字符串在字符数组中出现的位置
- 使用字符数组作为 Map 中的键
- C++:__aligned(__alignof__) 导致字符数组数据出现问题?
- 按顺序声明的字符数组重叠
- 在 C++ 中字符串的大小与字符数组的大小
- 寻找一种更好的方法来表示无符号字符数组
- 如何打印 2D 字符数组C++
- 从字符数组的元素中减去'a'是什么意思
- 我是否不正确地集中了这些字符数组?