扫码关注官方订阅号
同志们,我遇到个坑~~ 情况是这个样子的,我有个十六进制0x0f1c00000000000000000000 我要转换成二进制,然后这个有12个Byte长度,也就是说,我得输出来是96个数,例:100...11...11 但是我发现我不知道用哪个可以来输出了,求解决方案,long 和 int 不够用。。。。
学习是最好的投资!
超出 64 bit 范围的数组已经无法用一个基础类型表达了,写一个 uint8_t[] 来存这个大数字,用 Big-Endian 的字节序。
uint8_t[]
#include <stdint.h> uint8_t numbers[] = {0x0f, 0x1c, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0}; char bytes[97]; uint8_t current; for (size_t i = 0; i < sizeof(numbers); i++) { current = numbers[i]; for (size_t j = 0; j < 8; j++) { bytes[i * 8 + 7 - j] = (current & 1)? '1': '0'; current >>= 1; } } bytes[96] = '\0'; NSLog(@"numbers: %s", bytes);
16进制和2进制可以直接用“一一对应”的方式来转换的,即一个16进制数字,对应4个2进制数字。
1对应0001,2对应 0010,依次类推,f对应 1111
所以随便一个16进制数 abc, 转换方式是把 a换成 1010, b换成1011,c换成1100,拼起来结果就是101010111100
所以按这个规则,不管多长的16进制数字都能简单转换。
微信扫码关注PHP中文网服务号
QQ扫码加入技术交流群
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
PHP学习
技术支持
返回顶部
超出 64 bit 范围的数组已经无法用一个基础类型表达了,写一个
uint8_t[]来存这个大数字,用 Big-Endian 的字节序。16进制和2进制可以直接用“一一对应”的方式来转换的,即一个16进制数字,对应4个2进制数字。
1对应0001,2对应 0010,依次类推,f对应 1111
所以随便一个16进制数 abc, 转换方式是把 a换成 1010, b换成1011,c换成1100,拼起来结果就是101010111100
所以按这个规则,不管多长的16进制数字都能简单转换。