Behavior of VC in return type

  • Thread starter Thread starter Mohammad Omer
  • Start date Start date
M

Mohammad Omer

I am using vs2k5 for C++ IDE. I need to understand concept of the
following Code behavior on VC compiler.

Code-1
---
Object getObject()
{
return Object();
}

<In main function>
Object obj;
Obj = getObject();

Code-2
---
char * getTestArray()
{
char str[256];
strcpy(str, "this Text");
return str;
}

<In main function>
char text[256];
strcpy(text, getTestArray());

I really need answer of the following question,
1. What is the difference in code-1 and code-2 returning?
2. Will "strcpy(text, getTestArray());" statement make some problem in
feature??

Regards,
-aims
 
Mohammad Omer said:
I am using vs2k5 for C++ IDE. I need to understand concept of the
following Code behavior on VC compiler.

Code-1
---
Object getObject()
{
return Object();
}

<In main function>
Object obj;
Obj = getObject();

This makes a copy of the entire object into main's local variable, ok.
Code-2
---
char * getTestArray()
{
char str[256];
strcpy(str, "this Text");
return str;
}

<In main function>
char text[256];
strcpy(text, getTestArray());

This copies a pointer to getTestArray's local memory into main's local
memory. The array the pointer points to is no longer available, so your
program will have undefined behavior (read, random bad things will happen,
you could crash, you could overwrite important data, you could format your
hard disk). In this case, because you are only reading from the bad
pointer, and it's pointer to an invalid location on the stack, you will
probably just get nonsense data copied with strcpy. However, since strcpy
terminates based on finding a NUL character, not a buffer size, the garbage
might not have a NUL in the first 256 bytes, in which case strcpy would
overflow the destination array, overwrite strcpy's stack frame including the
return address, and your program will crash. memcpy, being controlled by
buffer length, wouldn't be so bad -- you'd get a controlled amount of
garbage and no stack corruption -- but the fundamental problem of returning
a pointer to a variable that goes out of scope needs to be corrected.
 
This copies a pointer to getTestArray's local memory into main's local
memory. The array the pointer points to is no longer available, so your
program will have undefined behavior (read, random bad things will happen,
you could crash, you could overwrite important data, you could format your
hard disk). In this case, because you are only reading from the bad
pointer, and it's pointer to an invalid location on the stack, you will
probably just get nonsense data copied with strcpy. However, since strcpy
terminates based on finding a NUL character, not a buffer size, the garbage
might not have a NUL in the first 256 bytes, in which case strcpy would
overflow the destination array, overwrite strcpy's stack frame including the
return address, and your program will crash. memcpy, being controlled by
buffer length, wouldn't be so bad -- you'd get a controlled amount of
garbage and no stack corruption -- but the fundamental problem of returning
a pointer to a variable that goes out of scope needs to be corrected.

void getTestArray(char * str)
{
strcpy(str, "this Text");
return str;
}

<In main function>
char text[256];
getTestArray(text);

what you suggest me, is this solution will solving abnormal behavior
of a code or strcpy function replace with memcpy function to insure
the memory crashes??

Regards,
-aims
 
Mohammad Omer said:
This copies a pointer to getTestArray's local memory into main's local
memory. The array the pointer points to is no longer available, so your
program will have undefined behavior (read, random bad things will
happen,
you could crash, you could overwrite important data, you could format
your
hard disk). In this case, because you are only reading from the bad
pointer, and it's pointer to an invalid location on the stack, you will
probably just get nonsense data copied with strcpy. However, since
strcpy
terminates based on finding a NUL character, not a buffer size, the
garbage
might not have a NUL in the first 256 bytes, in which case strcpy would
overflow the destination array, overwrite strcpy's stack frame including
the
return address, and your program will crash. memcpy, being controlled by
buffer length, wouldn't be so bad -- you'd get a controlled amount of
garbage and no stack corruption -- but the fundamental problem of
returning
a pointer to a variable that goes out of scope needs to be corrected.

void getTestArray(char * str)
{
strcpy(str, "this Text");
return str;
}

<In main function>
char text[256];
getTestArray(text);

what you suggest me, is this solution will solving abnormal behavior
of a code or strcpy function replace with memcpy function to insure
the memory crashes??

That code is correct, but it would be even better to also accept the buffer
length as an argument and check it before doing the copy. Otherwise another
caller could do:

char bad[2];
getTestArray(bad);

Which would crash the same as the first code you posted.
 
That code is correct, but it would be even better to also accept the buffer
length as an argument and check it before doing the copy. Otherwise another
caller could do:

char bad[2];
getTestArray(bad);

Which would crash the same as the first code you posted.

Right, I got the point. Thanks for guiding me. :)

Regards,
-aims
 
Back
Top