Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 31 Jan 2005 16:58:17 +0000
From:      Paul Richards <paul@originative.co.uk>
To:        Ulrich Spoerlein <q@uni.de>
Cc:        arch@freebsd.org
Subject:   Re: c99/c++ localised variable definition
Message-ID:  <20050131165817.GV61409@myrddin.originative.co.uk>
In-Reply-To: <20050131163117.GE828@galgenberg.net>
References:  <20050131122609.GA83556@gurney.reilly.home> <90392.1107174969@critter.freebsd.dk> <20050131163117.GE828@galgenberg.net>

next in thread | previous in thread | raw e-mail | index | archive | help
On Mon, Jan 31, 2005 at 05:31:17PM +0100, Ulrich Spoerlein wrote:
> On Mon, 31.01.2005 at 13:36:09 +0100, Poul-Henning Kamp wrote:
> > >If you carelessly c++-ify a loop like:
> > >
> > >	for (int i = 0; i < N; i++)
> > >	{
> > >		if (some_condition(i)) break;
> > >	}
> > >	do_something_with(i);	/* use finishing index */
> > >
> > >you can miss the fact that the value of i is used outside of the
> > >loop.  The newly created scope for "i" shadows the presumably
> > >pre-existing definition of i at the top of the function, which
> > >is what do_something_with() gets to see.
> > 
> > I would _really_ hope we have the compiler warning about this
> > already ?
> 
> Doesn't look so:
> #include <stdlib.h>
> #include <stdio.h>
> 
> int
> main(int argc, char **argv) {
>   int N = 42;
>   int i;
>   for (int i = 0; i < N; i++)
>     if (i == 23)
>       break;
>   printf("%d\n", i);   /* use finishing index */
>   return (0);
> }
> 
> % cc -Wall -std=c99 test.c && ./a.out
> 1

gcc should be throwing an uninitialised warning here.

> % icc -Wall -std=c99 test.c && ./a.out
> test.c(12): remark #592: variable "i" is used before its value is set
>     printf("%d\n", i);   /* use finishing index */
>                    ^
> 0
> 
> But the ICC warning is bogus too, if you happen to set i before, the
> warning disappears.

icc looks correct to me since the i being printed out is the one
in the outer scope which is unitialised.

-- 
Paul Richards



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20050131165817.GV61409>