On Tue Nov 22, 2005 at 16:16:29 +1100, O Plameras wrote:
>
>Hi ashley,
>
>I have three sets of codes that will do the task as I see it from your
>codes.
>I presented these three codes from the least to the most preferred coding.
>
>The common idea in all the three codes: 'somefunction' has static array
>of characters that is to be printed in 'main'; to accomplish this, just
>pass that address of the
>first character in a string to be printed. I changed the TYPE of
>'somefunction' from 'int' to 'char *' to achieve this end.
>
>I used malloc instead of calloc in Coding 2. It is sufficient in the
>context of your original codes.
>
>Notice I did not use calloc or malloc in Coding 3 as I am just passing
>an address.
>
>Coding 1.
>#include <stdio.h>
>#include <stdlib.h>
>#include <string.h>
>char *
>somefunction()
>{
> char *string1;
> char *string2 = "some words\0";
> string1 = (char *)calloc(strlen(string2 + 1), sizeof (char));
Should be strlen(string2) + 1
> strcpy(string1, string2);
> return string1;
>}
>int main (void)
>{
> char *string;
> string = somefunction();
> printf ("\n\nString is: %s\n\n", string);
> return 0;
>}
>
>Coding 2.
>#include <stdio.h>
>#include <stdlib.h>
>#include <string.h>
>char *
>somefunction()
>{
> char *string1;
> char *string2 = "some words\0";
> string1 = malloc(strlen(string2));
Should be strlen(string2) + 1
> strcpy(string1, string2);
> return string1;
>}
>int main (void)
>{
> char *string;
> string = somefunction();
> printf ("\n\nString is: %s\n\n", string);
> return 0;
>}
Moral of the story is don't code in C ;) Or if you do use as many tools
to help you as possible. -Wall, and a C linter are a good start.
Valgrind is also meant to be good, although I haven't
used it.
Benno
--
SLUG - Sydney Linux User's Group Mailing List - http://slug.org.au/
Subscription info and FAQs: http://slug.org.au/faq/mailinglists.html