100

size_t is defined as an unsigned integer, but the size of it depends on whether you're on a 32- or 64-bit machine. What's a correct and portable way to print out a size_t?

0

3 Answers 3

143

Try using the %zu format string

size_t val = get_the_value();
printf("%zu",val);

The z portion is a length specifier which says the argument will be size_t in length.

Source - http://en.wikipedia.org/wiki/Printf#printf_format_placeholders

Sign up to request clarification or add additional context in comments.

8 Comments

size_t is an unsigned type so you still need to use 'u' as the format type as well as the 'z' length modifier.
Also, the 'z' modifier is a C99 addition to printf, so its not strictly a standard C++ feature.
@Charles corrected the u portion and I added a C tag to the start. I would expect this to be much more a C feature than C++ as C++ can go the cout route.
My compiler (gcc) gives warning: unknown conversion type character 'z' in format [-Wformat]|, and when the program runs it just prints zu as the output
@Ruslan for that reason positional arguments have been introduced. See stackoverflow.com/questions/6322540/… . If they are used, your concern is not appicable.
|
10

There's a C++ tag on this, so cout << is another possible answer.

This is surprisingly hard to get right in all versions of C. In C90, casting to unsigned long should work, but that may well not work in C99, and the C99 solutions won't necessarily work in C90. The ability to reliably distinguish between C90 and C99 was introduced in the 1995 changes (specifying the allowable values for __STDC__). I don't think there is a completely portable way that works for C90, C99, and C++, although there are solutions for any individual one of those.

Comments

8

I think that the C++ answer is:

std::size_t n = 1;
std::cout << n;

For C-style IO it's a little more complicated. In C99 they added the z length modifier for size_t values. However, previous to TR1 this is not supported so you are left with casting to a specific size like:

std::size_t n = 1;
std::printf("%lu\n", static_cast<unsigned long>(n));

Then again, unsigned long long isn't really supported by C++ anyway so the above will work fine since unsigned long is the largest legal integral type. After TR1 you can use %zu safely for size_t values.

1 Comment

How is unsigned long long not supported by C++? If you're basing it off the sizeof being the same on some platforms that's not the same thing as it not being supported. Mind you I had a very bad reaction to C++ (even besides I find it hideous) and I love C but I've not encountered a C++ compiler that doesn't support unsigned long long. And certainly it supports uint64_t.

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.