tags:

views:

214

answers:

5

I just found this code on wikipedia.
Link: http://en.wikipedia.org/wiki/Sizeof#Use

The code:

/* the following code illustrates the use of sizeof 
 * with variables and expressions (no parentheses needed),
 * and with type names (parentheses needed)
 */

char c;

printf("%zu,%zu", sizeof c, sizeof(int));

It states that: "The z prefix should be used to print it, because the actual size can differ on each architecture."

I tried it on my compiler, but it gives the following result:

'zu,zu'

+7  A: 

Yes that syntax is correct (at least for C99). Looks like your compiler isn't set up to handle it though. Just take out the z and you'll probably be fine. To be correct, make sure your printf format specifiers match the size of the types. Turning on all the warnings your compiler will give you probably helps out in that respect.

Your quotation:

The z prefix should be used to print it, because the actual size can differ on each architecture

is referring to the fact that size_t (which is the type returned by the sizeof operator) can vary from architecture to architecture. The z is intended to make your code more portable. However, if your compiler doesn't support it, that's not going to work out. Just fiddle with combinations of %u, %lu, etc. until you get the output making sense.

Carl Norum
+1 for -Wall ...
drachenstern
You can use `%lu` and explicitly cast the `sizeof` value to `unsigned long` - as long as you know that the size of the object is less than 4GB you know then that it will definitely be reported correctly.
caf
+6  A: 

The z length modifier was added to C in the C99 standard; you might have a compiler that doesn't support C99.

If your C compiler doesn't support that, you can probably treat the sizes as unsigned long:

printf("%lu,%lu", (unsigned long)sizeof c, (unsigned long)sizeof(int));
nos
+1  A: 

Did you tell your compiler that you want it thinking with a C99 brain? There is probably a switch to do that. For instance, -std=c99 for gcc.

If your compiler does not support it, but you know others will, you can do a PRId64 style work around (disclaimer - PSEUDO CODE AHEAD ..):

#ifdef __SOME_KNOWN_C99_COMPILER
#define PORTUNSIGNED "zu"
#else
#define PORTUNSIGNED "u"
#endif

printf("%-11" PORTUNSIGNED " ways to skin a cat\n");

Its probably better to get a compiler that has functional support for c99, however.

Tim Post
The preprocessor is not evil.
George Edison
@George: That's not a universally held opinion.
David Thornley
@George - I'm not saying its evil, I'm just saying that some stop actually using it and start improvising with it, which leads to interesting things that other people eventually have to maintain :)
Tim Post
+2  A: 

Yes, but it only works on C99-compliant compilers. From wikipedia:

z: For integer types, causes printf to expect a size_t sized integer argument.

BlueRaja - Danny Pflughoeft
A: 

I've made a test using gcc 4.0. It works with -std=c99

pcent