I have had really big problems understand the char*
lately.
Let's say I made a recursive function to revert a char*
but depending on how I initialize it I get some access violations, and in my C++ primer I didn't find anything giving me the right path to understand so I am seeking your help.
CASE 1 First case where I got access violation when trying to swap letters around:
char * bob = "hello";
CASE 2 Then I tried this to get it work
char * bob = new char[5];
bob[0] = 'h';
bob[1] = 'e';
bob[2] = 'l';
bob[3] = 'l';
bob[4] = 'o';
CASE 3 But then when I did a cout I got some random crap at the end so I changed it for
char * bob = new char[6];
bob[0] = 'h';
bob[1] = 'e';
bob[2] = 'l';
bob[3] = 'l';
bob[4] = 'o';
bob[5] = '\0';
CASE 4 That worked so I told myself why wouldn't this work then
char * bob = new char[6];
bob = "hello\0";
CASE 5 and it failed, I have also read somewhere that you could do something like
char* bob[];
Then add something to that. My question is why do some fail and other not, and what is the best way to do it?
This actually translated to:
You can't change it, because if you'd written:
It could be translated to:
now, when you write:
First you assign one value to bob, then you assign a new value to it. What you really want to do here is:
The key is that some of these pointers are pointing at allocated memory (which is read/write) and some of them are pointing at string constants. String constants are stored in a different location than the allocated memory, and can't be changed. Well most of the time. Often vulnerabilities in systems are the result of code or constants being changed, but that is another story.
In any case, the key is the use of the new keyword, this is allocating space in read/write memory and thus you can change that memory.
This statement is wrong
because you are changing the pointer not copying the data. What you want is this:
or
You don't need the nul here because a string constant
"hello"
will have the null placed by the compiler.You should always use
char const*
for pointers to string literals (stuff in double quotes). Even though the standard allowschar*
as well, it does not allow writing to the string literal. GCC gives a compile warning for assigning a literal address intochar*
, but apparently some other compilers don't.Edit: The question was retagged as C++ instead of C which was originally there but re-tagged....
Ok. You have got a couple of things mixed up...new
is used by C++, not C.strcpy
to do that job, you cannot simply assign a string like that after callingnew
, when you declare a stringchar *s = "foo";
that is initialized at compile time. But when you do it this way,char *s = new char[6]; strcpy(s, "hello");
that gets copied into the pointer variables
.You will eventually discover that this pointer to a memory block occupied by
s
will easily get over-written which will induce a fit of conniptions as you realize that you have to be careful to prevent buffer overflows...Remember Case #3 in relation to nul terminator...don't forget that, really, that string's length is 6, not 5 as we're taking into account of the nul terminator.I know there is a lot to digest...but feel free to post any further thoughts... :) And best of luck in learning...