Date: Thu, 01 May 2003 15:31:40 -0700 From: Bakul Shah <bakul@bitblocks.com> To: Stefan Farfeleder <stefan@fafoe.dyndns.org> Cc: hackers@freebsd.org Subject: Re: incorrect enum warning? Message-ID: <200305012231.h41MVePF062201@bitblocks.com> In-Reply-To: Your message of "Fri, 02 May 2003 00:16:32 %2B0200." <20030501221631.GB546@wombat.fafoe>
next in thread | previous in thread | raw e-mail | index | archive | help
> > int main ()
> > {
> > printf("%d\n", (0x80000000 == INT_MIN));
> > return 0;
> > }
> >
> > ./a.out
> > 1
> >
> > Just pointing out that they do "==" each other, which is what was said.
>
> That is because the comparison is done in unsigned arithmetics due to
> the "usual arithmetic conversions". The negative int value INT_MIN is
> converted to unsigned int by adding UINT_MAX + 1 before the comparison
> is evaluated.
\begin{nitpicking}
0x80000000 is *not* an unsigned int, just a regular signed
int but outside the legal range. An unsigned int literal has
to have a U at the end. Since 0x80000000 > INT_MAX, all bets
are off. The result is unspecified and happens to be 1 on a
2s complement 32 bit machine but can be 0 or anything else on
a ones complement machine or where int is not 32 bits wide.
\end{nitpicking}
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200305012231.h41MVePF062201>
