Sdílet prostřednictvím


basic_string::reserve

Nastaví kapacitu řetězce na číslo, které je alespoň větší, než zadané číslo.

void reserve(
    size_type _Count = 0
);

Parametry

  • _Count
    Počet znaků, které je rezervované paměti.

Poznámky

S dostatečnou kapacitou je důležité, protože je časově náročné přesuny a zruší platnost všech odkazů, ukazatele a iterátory, které odkazují na znaky v řetězci.

Pojem kapacita pro objekty typu řetězce je stejný jako u objektů typu vector.Na rozdíl od vektorové členskou funkci rezervace může být volána zmenšení objemu objektu.Požadavek je nonbinding a mohou nebo nemusí být proveden.Jako výchozí hodnotu pro parametr nulová, je volání rezervace je nezávazné požadavek na zmenšení objemu řetězec právě podle počtu znaků v řetězci.Kapacita nikdy neklesl pod aktuální počet znaků.

Volání reserve je jediným možným způsobem zmenšení objemu řetězec.Jak bylo uvedeno výše, tento požadavek se však nonbinding a nemusí dojít.

Příklad

// 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;
}
  

Požadavky

Hlavička: <string>

Obor názvů: std

Viz také

Referenční dokumentace

basic_string – třída