• C

FOR loop variable

What happens with X in the following code ? Where is it stored ? How many times is it stored ?
(Basically what would the assembly look like ?)

for( int i=0;i<i+1; i++ )
{
  unsigned char X;<- What happens here ?
  do_something( &X );
}

Is there any difference if it would have
been
unsigned char X=1; ??

LVL 1
CrypToniCAsked:
Who is Participating?

Improve company productivity with a Business Account.Sign Up

x
 
rbrConnect With a Mentor Commented:
Stored locally on the stack. Livetime between the 2 { }. So the variable starts living after the { and is removed by the }

The only differnces between
unsigned char X;
and
unsigned char X=1;

is that in the second case the X becomes 1 at the start of the loop.

btw.

for( int i=0;i<i+1; i++ )

while loop till an overflow.
0
 
CrypToniCAuthor Commented:
Locally on the stack only
initialized (and copied) once ?

BTW yez it does overflow but it was
just a silly example :)
0
 
rbrCommented:
yes initalized onced. What to you mean with copied?
0
What Kind of Coding Program is Right for You?

There are many ways to learn to code these days. From coding bootcamps like Flatiron School to online courses to totally free beginner resources. The best way to learn to code depends on many factors, but the most important one is you. See what course is best for you.

 
anand_007Commented:
No! Your X is going to get initialized every time! So, once ur loop i executed, x is reinitialized during the next runof ur loop! By the way, it's dangerous to use ur comparison statement x<x+1 -- it'll always be so!! Stack dump indeed -- try using UNIX u'll be CORE-Dumped!  
0
 
rbrCommented:
Pls read my answer carefully. I said x becomes 1 at the start at loop I mean it is intialized once for a loop.
0
 
CrypToniCAuthor Commented:
People forget about the syntax for the
darn FOR - loop it is not interesting

rbr - one last thing
Would you initialize X inside the FOR
or outside, consider the case where
x: unsigned char X . No initialization
is done

BTW if i is a 16-bit number
wouldn't for( i;i<i+1;i++)
be equal to for( ;; ), since 32767<(32767+1 == -32768) Why would it neccessarily mean a stack dump ?
0
 
rbrCommented:
It depends on what you want to do.

e.g.

int main (int argn,char *argv[])
{

    int i;  
    printf ("Start");
 
   for (i=0;i<5;i++) {
       int j=1;
       j*=j;

       printf ("%d",j);
   }
   return 0;
}

and

int main (int argn,char *argv[])
{

   int i;  
   int j=1;
   printf ("Start");
 
   for (i=0;i<5;i++) {
       j*=j;

       printf ("%d",j);
   }
   return 0;
}

will lead to the same result. The differnces is that in the first example j is not accessable from outside the loop. (you could have a differnet j outside to loop)

32767<(32767+1 == -32768) is false so the loop ends. But many OSs produces a fault when a overflow occurs.
0
 
CrypToniCAuthor Commented:
So there is no performance difference ?
0
 
rbrCommented:
Couldn't be answered for general. You don't know what your compiler does during optimization.
0
 
anand_007Commented:
Right, now that we know about command line arguments, what's theproblem again??
0
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

All Courses

From novice to tech pro — start learning today.