I usually use pointers in the following manner
char *ptr = malloc( sizeof(char) * 100 ); memset( ptr, 0, 100 ) ; strncpy( ptr, "cat" , 100 - 1 );
But this time instead o开发者_运维问答f using "cat", I want to use it ASCII equivalent in hex.
cat = 0x63, 0x61, 0x74, 0x00
I tried
strncpy( ptr, "0x630x61" , 100 - 1 );
But it fails as expected.
What is the correct syntax?
Do I need to put a 0x00 too? For a moment lets forget about memset
, now do I need to put a 0x00? Because in "cat" notation, a null is automatically placed.
Regards
\xXX
is the syntax for inserting characters in hex format. so yours would be:
strncpy( ptr, "\x63\x61\x74", 100 - 1);
You don't need to put in a \x00
since having quotes automatically null-delimits the string.
Note, you only need \ inside the " " string
char cat[4];
cat[0] = 0x63;
cat[1] = 0x61;
cat[2] = 0x74;
car[3] = 0x00;
char cat[] = "\x63\x61\x74"; // note the \0 is added for you
char cat[] = { 0x63, 0x61, 0x74, 0x00 };
Are all the same
strncpy( ptr, "\x63\x61" , 100 - 1 );
0x63
is an integer hexadecimal literal; The C compiler parses it as such within code. But within a string it is interpreted as a sequence of characters 0,x,6,3
.
The literal for the char
with value 63 hex. is '\x63'
, and within strings you must use this notation.
"c\x63"
is the literal for a zero-terminated string, irrespective of the characters within the quotes (or of the notation by which you denote them), so no, you don't need to append a trailing zero manually.
精彩评论