Search code examples
c++initializationundefined-behavior

What should happen when printing an uninitialized variable?


I've checked myself, I wrote a program like this

int main() {
 int i;
 cout << i;
 return 0;
}

I ran the program a few times and the result was same all the time, zero. I've tried it in C and the result was the same.

But my textbook says

If you don’t initialize an variable that’s defined inside a function, the variable value remain undefined.That means the element takes on whatever value previously resided at that location in memory.

How's this possible when the program always assign a free memory location to a variable? How could it be something other than zero (I assume that default free memory value is zero)?


Solution

  • How's this possible when the program always assign a free memory location to a variable? How could it be something rather than zero?

    Let's take a look at an example practical implementation.

    Let's say it utilizes stack to keep local variables.

    void
    foo(void)
    {
            int foo_var = 42;
    }
    
    void
    bar(void)
    {
            int bar_var;
            printf("%d\n", bar_var);
    }
    
    int
    main(void)
    {
            bar();
            foo();
            bar();
    }
    

    Totally broken code above illustrates the point. After we call foo, certain location on the stack where foo_var was placed is set to 42. When we call bar, bar_var occupies that exact location. And indeed, executing the code results in printing 0 and 42, showing that bar_var value cannot be relied upon unless initialized.

    Now it should be clear that local variable initialisation is required. But could main be an exception? Is there anything which could play with the stack and in result give us a non-zero value?

    Yes. main is not the first function executed in your program. In fact there is tons of work required to set everything up. Any of this work could have used the stack and leave some non-zeros on it. Not only you can't expect the same value on different operating systems, it may very well suddenly change on the very system you are using right now. Interested parties can google for "dynamic linker".

    Finally, the C language standard does not even have the term stack. Having a "place" for local variables is left to the compiler. It could even get random crap from whatever happened to be in a given register. It really can be totally anything. In fact, if an undefined behaviour is triggered, the compiler has the freedom to do whatever it feels like.