Last active
July 1, 2024 06:22
-
-
Save leonid-ed/5b9161531afdafe65bca to your computer and use it in GitHub Desktop.
This function prints hex dump of memory specified as a pointer
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/* | |
* This function prints hex dump of memory specified as a pointer. | |
* Reference: http://stackoverflow.com/questions/7775991/how-to-get-hexdump-of-a-structure-data | |
*/ | |
#include <stdio.h> | |
void hexDump(char *desc, void *addr, int len) | |
{ | |
int i; | |
unsigned char buff[17]; | |
unsigned char *pc = (unsigned char*)addr; | |
// Output description if given. | |
if (desc != NULL) | |
printf ("%s:\n", desc); | |
// Process every byte in the data. | |
for (i = 0; i < len; i++) { | |
// Multiple of 16 means new line (with line offset). | |
if ((i % 16) == 0) { | |
// Just don't print ASCII for the zeroth line. | |
if (i != 0) | |
printf (" %s\n", buff); | |
// Output the offset. | |
printf (" %04x ", i); | |
} | |
// Now the hex code for the specific character. | |
printf (" %02x", pc[i]); | |
// And store a printable ASCII character for later. | |
if ((pc[i] < 0x20) || (pc[i] > 0x7e)) | |
buff[i % 16] = '.'; | |
else | |
buff[i % 16] = pc[i]; | |
buff[(i % 16) + 1] = '\0'; | |
} | |
// Pad out last line if not exactly 16 characters. | |
while ((i % 16) != 0) { | |
printf (" "); | |
i++; | |
} | |
// And print the final ASCII bit. | |
printf (" %s\n", buff); | |
} | |
int main (int argc, char *argv[]) { | |
char my_str[] = "a char string greater than 16 chars"; | |
hexDump ("my_str", &my_str, sizeof (my_str)); | |
return 0; | |
} | |
/* stdout | |
my_str: | |
0000 61 20 63 68 61 72 20 73 74 72 69 6e 67 20 67 72 a char string gr | |
0010 65 61 74 65 72 20 74 68 61 6e 20 31 36 20 63 68 eater than 16 ch | |
0020 61 72 73 00 ars. | |
*/ |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment