这篇文章主要讲解了“C++中数据16进制输出的方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++中数据16进制输出的方法是什么”吧!
比如我们得到一个数据:
double b = 123456789.987;
因为我要使用的是其整数部分,所以对w进行数据转换:
__int64 B = __int64(b);
我们就得到了64位整型的w1,接下来我们要将w1以0x16进制的形式插入到一个数组中:
unsigned char A[46] = { 0x12, 0xAB, 0x34, 0xCD};
因为,B是以16进制储存在电脑里的,所以我们采用直接移位的方式,进行插入,比如我要将B以4个字节的形式插入到A后:
A[4] = (B >> 24) & 0xFF; A[5] = (B >> 16) & 0xFF; A[6] = (B >> 8) & 0xFF; A[7] = (B >> 0) & 0xFF;
整体代码如下:
#include<stdio.h> int main() { double b = 123456789.987; __int64 B = __int64(b); unsigned char A[46] = { 0x12, 0xAB, 0x34, 0xCD }; A[4] = (B >> 24) & 0xFF; A[5] = (B >> 16) & 0xFF; A[6] = (B >> 8) & 0xFF; A[7] = (B >> 0) & 0xFF; for (int i = 0; i < 8; i++) { printf("%02X ", A[i]); } return 0; }
运行结果如下: