%02x (x代表以十六進制形式輸出,02代表不足兩位,前面補0輸出,如果超過兩位,則以實際輸出)
例:
#include <stdio.h> #include <stdint.h> #include <string.h> typedef struct xxx{ uint8_t a; uint8_t b; uint32_t c; } stu; int main() { int i; stu s; memset(&s, 0, sizeof(s)); s.a = 0x01; s.b = 0x02; s.c = 0x1C080206; unsigned char *p = (unsigned char *)&s; for (i = 0; i < sizeof(s); i++) { printf("p[%d] = %02x\n", i, p[i]); } return 0; }
運行結果:
p[0] = 01
p[1] = 02
p[2] = 00
p[3] = 00
p[4] = 06
p[5] = 02
p[6] = 08
p[7] = 1c
PS: 不考慮大小端和內存對齊。
%2x (數據不足兩位,實際輸出;注意:不會額外補0,如果超過兩位,則以實際輸出)
例:
#include <stdio.h> #include <stdint.h> #include <string.h> typedef struct xxx{ uint8_t a; uint8_t b; uint32_t c; } stu; int main() { int i; stu s; memset(&s, 0, sizeof(s)); s.a = 0x01; s.b = 0x02; s.c = 0x1C080206; unsigned char *p = (unsigned char *)&s; for (i = 0; i < sizeof(s); i++) { printf("p[%d] = %2x\n", i, p[i]); } return 0; }
運行結果:
p[0] = 1
p[1] = 2
p[2] = 0
p[3] = 0
p[4] = 6
p[5] = 2
p[6] = 8
p[7] = 1c