Mail Archives: djgpp/1996/05/06/12:31:09
From: watzka AT stat DOT uni-muenchen DOT de (Kurt Watzka)
Date: 6 May 1996 00:34:37 GMT
nmarrone AT smartlink DOT net (Nicholas Marrone) writes:
> int *origp;
> int *onesp, *zerop;
> int ticks; /* for use with the clock in randomizing shtuff */
> if ( !(origp = (int *)malloc(NUM * 2)) ||
> !(onesp = (int *)malloc(NUM * 2)) ||
> !(zerop = (int *)malloc(NUM * 2)) )
> {
> printf("Not enough memory to run this program!!!");
> }
The casts of the return value from malloc to "int *" is not needed in
a C program, nor does it contribute anything good or bad to your
program.
Actually, I would encourage Mr. Marrone to continue to cast the return of
malloc(). I believe that it contributes SOMETHING VERY GOOD, it improves the
documentation value of the code with little added effort. It documented his
intent well enough that you spotted his biggest problem!!!!!!!!!!!! I've been
programming in "C" for 15 years and I hope I never get jaded enough or lazy
enough to stop adding types casts wherever an automatic cast would occur. Then
I, an anyone else reading my code, will know what I have done and that it was
intentional (I might still be WRONG, but intentional and how much easier to fix
when the error is made glaring this way)!
OTOH, I hope you use only "(NUM * 2) / sizeof(int)" elements of each
array.
I assume that you assume that sizeof(int) is 2 in your implementation.
A good way to aviod this problem is to use the sizeof operator in
malloc() and similar statements:
And of course in DJGPP, as a 32 bit compiler, int's are 4 bytes.
<STUFF DELETED>
--
Art S. Kagel, kagel AT quasar DOT bloomberg DOT com
A proverb is no proverb to you 'till life has illustrated it. -- John Keats
- Raw text -