这个例子显示了两个有趣的东西。首先,虽然我们要求200的能力,我们实际上有一个容量207。能力总是保证至少和你一样大的要求,但可能更大。然后我们要求的能力改变以适应字符串。这个请求被忽略,因为能力并没有改变。
如果你事先知道你要做大量的字符串操作,将添加到字符串的大小构建一个大的字符串,你可以避免字符串分配多次立即设置字符串到它的最终容量:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#include <iostream>
#include <string>
#include <cstdlib> // for rand() and srand()
#include <ctime> // for time()
using namespace std;
int main()
{
srand(time(0)); // seed random number generator
string sString; // length 0
sString.reserve(64); // reserve 64 characters
// Fill string up with random lower case characters
for (int nCount=0; nCount < 64; ++nCount)
sString += 'a' + rand() % 26;
cout << sString;
}
这个程序的结果将改变每一次,但这是从一个执行的输出:
而不必重新分配sString多次,我们设置的能力一次然后填充字符串。这可以使一个巨大的性能差异在构建大型字符串通过级联。
如果你事先知道你要做大量的字符串操作,将添加到字符串的大小构建一个大的字符串,你可以避免字符串分配多次立即设置字符串到它的最终容量: