How Not To Test Pointers

Pointer tests in the realm of implementation-dependent behavior

So, what’s wrong with this little snippet of code:

extern void *foo();

void *p = foo();
if( p > 0 )
{
printf( “Pointer is okay\n” );
}

When I saw this, my first thought was that I’d never seen that done, nor had I ever imagined anyone doing it.

The compiler apparently liked it just fine, but the behavior was not what the person who wrote that line of code expected – i.e. the conditional evaluated false on a non-null pointer.

According to H&S , the behavior in this case is undefined unless the pointers being compared point into the same array or structure.

Bottom line – don’t do that! The normal four ways to test a pointer always work.

if( p )
if( ! p )
if( p == 0 )
if( p != 0 )

(And, no, this wasn’t my code! 🙂

Leave a Reply

Fill in your details below or click an icon to log in:

WordPress.com Logo

You are commenting using your WordPress.com account. Log Out /  Change )

Twitter picture

You are commenting using your Twitter account. Log Out /  Change )

Facebook photo

You are commenting using your Facebook account. Log Out /  Change )

Connecting to %s

%d bloggers like this: