不多说,直接上代码:
#include <stdio.h>
typedef unsigned char *byte_pointer;
void show_bytes(byte_pointer start, int len) {
int i;
for (i = 0; i < len; i++) {
printf(" %.2x", start[i]);
}
printf("\n");
}
void show_int(int x) {
printf("int:\t");
show_bytes((byte_pointer)&x, sizeof(x));
}
void show_float(float x) {
printf("float:\t");
show_bytes((byte_pointer)&x, sizeof(x));
}
void show_pointer(void *x) {
printf("pointer:");
show_bytes((byte_pointer)&x, sizeof(void *));
}
void test_show_bytes(int val) {
int ival = val;
float fval = (float)ival;
int *pval = &ival;
show_int(ival);
show_float(fval);
show_pointer(pval);
}
int main() {
int val = 12345;
printf("value:\t%d --> %x\n", val, val);
test_show_bytes(val);
return 0;
}
50行代码即可证明这个问题的详细过程,下面是运行截图: