Delirium tremens
Delirium tremens

Reputation: 4749

string::size_type instead of int

const std::string::size_type cols = greeting.size() + pad * 2 + 2;

Why string::size_type? int is supposed to work! it holds numbers!!!

Upvotes: 71

Views: 67999

Answers (4)

user22918172
user22918172

Reputation: 1

size_t and std::string::size_type are the same types except for one important difference: Were they both will represent a value of any size, std::string::size_type (A member of std::string) uses a static constant value of -1 to represent npos. one past the end of the string. It tells the program that you have reached the end of the string. If you are using search, find, erase, replace, or any other modifying operations on strings, or writing your own then you may want to prefer std::string::size_type. If you are just iterating over the string size_t is probably fine.

Upvotes: -1

mihai
mihai

Reputation: 4742

The example that you've given,

const std::string::size_type cols = greeting.size() + pad * 2 + 2;

is from Accelerated C++ by Koenig. He also states the reason for his choice right after this, namely:

The std::string type defines size_type to be the name of the appropriate type for holding the number of characters in a string. Whenever we need a local variable to contain the size of a string, we should use std::string::size_type as the type of that variable.

The reason that we have given cols a type of std::string::size_type is to ensure that cols is capable of containing the number of characters in greeting, no matter how large that number might be. We could simply have said that cols has type int, and indeed, doing so would probably work. However, the value of cols depends on the size of the input to our program, and we have no control over how long that input might be. It is conceivable that someone might give our program a string so long that an int is insufficient to contain its length.

Upvotes: 26

Marc Mutz - mmutz
Marc Mutz - mmutz

Reputation: 25313

A nested size_type typedef is a requirement for STL-compatible containers (which std::string happens to be), so generic code can choose the correct integer type to represent sizes.

There's no point in using it in application code, a size_t is completely ok (int is not, because it's signed, and you'll get signed/unsigned comparison warnings).

Upvotes: 7

Stack Overflow is garbage
Stack Overflow is garbage

Reputation: 248199

A short holds numbers too. As does a signed char.

But none of those types are guaranteed to be large enough to represent the sizes of any strings.

string::size_type guarantees just that. It is a type that is big enough to represent the size of a string, no matter how big that string is.

For a simple example of why this is necessary, consider 64-bit platforms. An int is typically still 32 bit on those, but you have far more than 2^32 bytes of memory.

So if a (signed) int was used, you'd be unable to create strings larger than 2^31 characters. size_type will be a 64-bit value on those platforms however, so it can represent larger strings without a problem.

Upvotes: 118

Related Questions