Поделиться через


basic_string::reserve

Задает емкость строки в число, по крайней мере, как большим, как заданное число.

void reserve(
    size_type _Count = 0
);

Параметры

  • _Count
    Число символов, для которых памяти зарезервировано.

Заметки

Быть достаточно емкость важно, поскольку перераспределения трудоемких процесс и делает недействительной все ссылки, и итераторы, которые относятся к символам в строке.

Понятие вместимости для объектов строк типа такое же, как у объектов vector типа.В отличие от вектор, функция-член reserve может быть вызван для сжатия емкость объекта.Запрос nonbinding и может вернуть или не произойти.В качестве значения по умолчанию для параметра равно нулю, вызов reserve запрос привязки, отличного от сжатия емкость строки адаптация число символов в данный момент в строке.Емкость никогда не уменьшается в разделе текущему числу знаков.

Вызов reserve единственный возможный способ сжатия емкость строки.Однако как указано выше, этот запрос nonbinding и не может произойти.

Пример

// basic_string_reserve.cpp
// compile with: /EHsc
#include <string>
#include <iostream>

int main( ) 
{
   using namespace std;
   string str1 ("Hello world");
   cout << "The original string str1 is: " << str1 << endl;

   basic_string <char>::size_type sizeStr1, sizerStr1;
   sizeStr1 = str1.size ( );
   basic_string <char>::size_type capStr1, caprStr1;
   capStr1 = str1.capacity ( );

   // Compare size & capacity of the original string
   cout << "The current size of original string str1 is: " 
        << sizeStr1 << "." << endl;
   cout << "The capacity of original string str1 is: "
        << capStr1 << "." << endl << endl;

   // Compare size & capacity of the string
   // with added capacity
   str1.reserve ( 40 );
   sizerStr1 = str1.size ( );
   caprStr1 = str1.capacity ( );

   cout << "The string str1with augmented capacity is: "
        << str1 << endl;
   cout << "The current size of string str1 is: " 
        << sizerStr1 << "." << endl;
   cout << "The new capacity of string str1 is: "
        << caprStr1 << "." << endl << endl;

   // Compare size & capacity of the string
   // with downsized capacity
   str1.reserve ( );
   basic_string <char>::size_type sizedStr1;
   basic_string <char>::size_type capdStr1;
   sizedStr1 = str1.size ( );
   capdStr1 = str1.capacity ( );

   cout << "The string str1 with downsized capacity is: "
        << str1 << endl;
   cout << "The current size of string str1 is: " 
        << sizedStr1 << "." << endl;
   cout << "The reduced capacity of string str1 is: "
        << capdStr1 << "." << endl << endl;
}
  
  
  
  
  
  

Требования

заголовок: <string>

std пространство имен:

См. также

Ссылки

basic_string Class