Groovy hepcat Bail was jivin' on 16 Nov 2005 21:02:54 -0800 in
comp.lang.c.
Help on understanding Structs's a cool scene! Dig it!
I will have a exam on the oncoming friday, my professor told us that it
I realise I'm too late with this followup, but just in case you're
still wondering about it...
will base upon this program. i am having troubles understanding this
Well, what don't you understand? It's pretty straight forward,
notwithstanding the numerous inadequecies, which I have outlined. Do I
understand correctly that your professor supplied this code? If so, YE
GADS! What's he a professor of, needlepoint?
program, for example what if i want to add all the total calories that
the user input together. determine which food has the largest calories.
how do i start to modifiy the program inorder to do the things i listed
above. thanks
#include <stdio.h>
#include <stdlib.h>
typedef struct {
char *name;
int calories;
int group;
} FOOD;
void getFood(FOOD foods[ ], int i ) {
FOOD newFood;
void *characters = malloc(81*sizeof(char));
sizeof(char) is 1.
You *must* check the return value of malloc() for a null pointer
(indicating an error). malloc() can fail, y'know; and when it does,
you must not try to dereference the pointer.
Why is characters a pointer to void? If you want to store characters
in the memory it points at, then wouldn't a pointer to char be better?
printf("\nPlease enter the requested information:\n");
printf(" for food item %d, what is\n", i+1);
printf(" the name? ");
This prompt may not be displayed straight away. Use fflush() to
flush stdout to better the chances of seeing the prompt.
fflush(stdout);
gets( characters); // NOTE fgets IS BETTER!
Never use gets(). Just never use gets(). As you (or, presumably your
professor) say in the comment, fgets() is better. Why, then, didn't
you (or he) use fgets()? gets() is a disaster waiting to happen. Never
use it. Use fgets() instead. Never use gets(). Read the FAQ for more
on this; and never use gets(). Just to reiterate: never use gets().
By the way, don't use C++ style comments here. There are (at least)
two good reasons for this. First, many people here still use pre-C99
compilers, which don't support C++ style comments. And second, lines
have a way of wrapping around here. When that happens it makes
cutting, pasting and compiling dificult. Original C comments (/*...*/)
are well behaved when they wrap around. C++ comments are not.
newFood.name = characters;
printf(" calories/serving? ");
This prompt may not be displayed straight away. Use fflush() to
flush stdout to better the chances of seeing the prompt.
fflush(stdout);
scanf("%d", &(newFood.calories));
printf(" food group? ");
This prompt may not be displayed straight away. Use fflush() to
flush stdout to better the chances of seeing the prompt.
fflush(stdout);
scanf("%d", &(newFood.group));
printf("\n");
foods = newFood;
You're not going to return some status value to indicate
success/failure conditions?
} // end getFood // note:a struct is and lvalue !!
What's the point of this useless comment? Comments should make code
clearer, easier to read. They should not just clutter the code with
useless garbage.
void dump( FOOD foods[ ] , int n ) {
int i;
for(i=0; i<n; i++ ) {
printf("Food %d is: \n", i+1);
printf(" name : %s\n", foods.name);
printf(" calories: %d\n", foods.calories);
printf(" group # : %d\n", foods.group);
printf("\n");
} // end for
} // end dump
More useless comments!
int main( ) {
int num; // number of foods entered
And another one!
int i;
char dum[81];
printf("\nHow many foods will you enter? ");
This prompt may not be displayed straight away. Use fflush() to
flush stdout to better the chances of seeing the prompt.
fflush(stdout);
scanf("%d", &num);
FOOD foods[num];
Won't work in pre-C99 implementations, where an array's bounds must
be declared by a constant. Instead, you should use malloc() (and do
remember to check the return value).
for( i=0; i<num; i++ ) {
gets(dum); //NOTE: THIS IS HERE BECAUSE OF SCANF
Huh? What do you (or your prof) mean? You mean scanf() is leaving a
newline (or other garbage) in the stream to be picked up by the next
input function? Well, then, what does that say about the way you are
using scanf()? What does it say about the whole input strategy? Not
very good, is it? Consult the FAQ on this.
Oh, and by the way, did I mention that you should never use gets()?
Well, you should never use gets().
getFood( foods, i );
} // end for
dump( foods, num);
What about relinquishing the memory allocated in getFood()? Very
poor form, leaving this undone!
Poor (inconsistent) indentation! This sort of thing can make code
harder to read.
If your professor wrote this code, I'd seriously think about
changing schools. It's horrendous! I'd expect a rank beginner to write
code like that, not a professor (unless he were a professor of
something totally unrelated to programming).
But the logic is pretty simple. Here is a basic breakdown of it.
1) First it asks the user to enter the number of foods he/she wishes
to enter, then reads in that number.
2) Next it creates an array of structures used to hold the food data.
3) Then it goes into a loop that calls a function that
a) asks the user the name of the food and reads in the name, having
first allocated memory in which to store it,
b) asks the user for the number of calories and reads in the
number,
c) asks the user for the food group (a number) and reads in the
number, and
d) stores this information in an element of the array.
4) Lastly it calls a function that displays the information stored in
the array.
--
Dig the even newer still, yet more improved, sig!
http://alphalink.com.au/~phaywood/
"Ain't I'm a dog?" - Ronny Self, Ain't I'm a Dog, written by G. Sherry & W. Walker.
I know it's not "technically correct" English; but since when was rock & roll "technically correct"?