typedef _Alloc allocator_type
typedef __gnu_cxx::__normal_iterator< const_pointer, basic_string > const_iterator
typedef _CharT_alloc_type::const_pointer const_pointer
typedef _CharT_alloc_type::const_reference const_reference
typedef std::reverse_iterator< const_iterator > const_reverse_iterator
typedef _CharT_alloc_type::difference_type difference_type
typedef __gnu_cxx::__normal_iterator< pointer, basic_string > iterator
typedef _CharT_alloc_type::pointer pointer
typedef _CharT_alloc_type::reference reference
typedef std::reverse_iterator< iterator > reverse_iterator
typedef _CharT_alloc_type::size_type size_type
typedef _Traits traits_type
typedef _Traits::char_type value_type
basic_string ()
Default constructor creates an empty string.
basic_string (const _Alloc &__a)
Construct an empty string using allocator a.
basic_string (const basic_string &__str)
Construct string with copy of value of str.
basic_string (const basic_string &__str, size_type __pos, const _Alloc &__a=_Alloc())
Construct string as copy of a substring.
basic_string (const basic_string &__str, size_type __pos, size_type __n)
Construct string as copy of a substring.
basic_string (const basic_string &__str, size_type __pos, size_type __n, const _Alloc &__a)
Construct string as copy of a substring.
basic_string (const _CharT *__s, size_type __n, const _Alloc &__a=_Alloc())
Construct string initialized by a character array.
basic_string (const _CharT *__s, const _Alloc &__a=_Alloc())
Construct string as copy of a C string.
basic_string (size_type __n, _CharT __c, const _Alloc &__a=_Alloc())
Construct string as multiple characters.
basic_string (basic_string &&__str) noexcept
Move construct string.
basic_string (initializer_list< _CharT > __l, const _Alloc &__a=_Alloc())
Construct string from an initializer list.
template<class _InputIterator > basic_string (_InputIterator __beg, _InputIterator __end, const _Alloc &__a=_Alloc())
Construct string as copy of a range.
~basic_string () noexcept
Destroy the string instance.
template<typename _InputIterator > basic_string< _CharT, _Traits, _Alloc > & _M_replace_dispatch (iterator __i1, iterator __i2, _InputIterator __k1, _InputIterator __k2, __false_type)
template<typename _InIterator > _CharT * _S_construct (_InIterator __beg, _InIterator __end, const _Alloc &__a, forward_iterator_tag)
basic_string & append (const basic_string &__str)
Append a string to this string.
basic_string & append (const basic_string &__str, size_type __pos, size_type __n=npos)
Append a substring.
basic_string & append (const _CharT *__s, size_type __n)
Append a C substring.
basic_string & append (const _CharT *__s)
Append a C string.
basic_string & append (size_type __n, _CharT __c)
Append multiple characters.
basic_string & append (initializer_list< _CharT > __l)
Append an initializer_list of characters.
template<class _InputIterator > basic_string & append (_InputIterator __first, _InputIterator __last)
Append a range of characters.
basic_string & assign (const basic_string &__str)
Set value to contents of another string.
basic_string & assign (basic_string &&__str)
Set value to contents of another string.
basic_string & assign (const basic_string &__str, size_type __pos, size_type __n=npos)
Set value to a substring of a string.
basic_string & assign (const _CharT *__s, size_type __n)
Set value to a C substring.
basic_string & assign (const _CharT *__s)
Set value to contents of a C string.
basic_string & assign (size_type __n, _CharT __c)
Set value to multiple characters.
template<class _InputIterator > basic_string & assign (_InputIterator __first, _InputIterator __last)
Set value to a range of characters.
basic_string & assign (initializer_list< _CharT > __l)
Set value to an initializer_list of characters.
const_reference at (size_type __n) const
Provides access to the data contained in the string.
reference at (size_type __n)
Provides access to the data contained in the string.
reference back ()
const_reference back () const noexcept
iterator begin ()
const_iterator begin () const noexcept
const _CharT * c_str () const noexcept
Return const pointer to null-terminated contents.
size_type capacity () const noexcept
const_iterator cbegin () const noexcept
const_iterator cend () const noexcept
void clear () noexcept
int compare (const basic_string &__str) const
Compare to a string.
int compare (size_type __pos, size_type __n, const basic_string &__str) const
Compare substring to a string.
int compare (size_type __pos1, size_type __n1, const basic_string &__str, size_type __pos2, size_type __n2=npos) const
Compare substring to a substring.
int compare (const _CharT *__s) const noexcept
Compare to a C string.
int compare (size_type __pos, size_type __n1, const _CharT *__s) const
Compare substring to a C string.
int compare (size_type __pos, size_type __n1, const _CharT *__s, size_type __n2) const
Compare substring against a character array.
size_type copy (_CharT *__s, size_type __n, size_type __pos=0) const
Copy substring into C string.
const_reverse_iterator crbegin () const noexcept
const_reverse_iterator crend () const noexcept
const _CharT * data () const noexcept
Return const pointer to contents.
bool empty () const noexcept
iterator end ()
const_iterator end () const noexcept
basic_string & erase (size_type __pos=0, size_type __n=npos)
Remove characters.
iterator erase (iterator __position)
Remove one character.
iterator erase (iterator __first, iterator __last)
Remove a range of characters.
size_type find (const _CharT *__s, size_type __pos, size_type __n) const noexcept
Find position of a C substring.
size_type find (const basic_string &__str, size_type __pos=0) const noexcept
Find position of a string.
size_type find (const _CharT *__s, size_type __pos=0) const noexcept
Find position of a C string.
size_type find (_CharT __c, size_type __pos=0) const noexcept
Find position of a character.
size_type find_first_not_of (const basic_string &__str, size_type __pos=0) const noexcept
Find position of a character not in string.
size_type find_first_not_of (const _CharT *__s, size_type __pos, size_type __n) const noexcept
Find position of a character not in C substring.
size_type find_first_not_of (const _CharT *__s, size_type __pos=0) const noexcept
Find position of a character not in C string.
size_type find_first_not_of (_CharT __c, size_type __pos=0) const noexcept
Find position of a different character.
size_type find_first_of (const basic_string &__str, size_type __pos=0) const noexcept
Find position of a character of string.
size_type find_first_of (const _CharT *__s, size_type __pos, size_type __n) const noexcept
Find position of a character of C substring.
size_type find_first_of (const _CharT *__s, size_type __pos=0) const noexcept
Find position of a character of C string.
size_type find_first_of (_CharT __c, size_type __pos=0) const noexcept
Find position of a character.
size_type find_last_not_of (const basic_string &__str, size_type __pos=npos) const noexcept
Find last position of a character not in string.
size_type find_last_not_of (const _CharT *__s, size_type __pos, size_type __n) const noexcept
Find last position of a character not in C substring.
size_type find_last_not_of (const _CharT *__s, size_type __pos=npos) const noexcept
Find last position of a character not in C string.
size_type find_last_not_of (_CharT __c, size_type __pos=npos) const noexcept
Find last position of a different character.
size_type find_last_of (const basic_string &__str, size_type __pos=npos) const noexcept
Find last position of a character of string.
size_type find_last_of (const _CharT *__s, size_type __pos, size_type __n) const noexcept
Find last position of a character of C substring.
size_type find_last_of (const _CharT *__s, size_type __pos=npos) const noexcept
Find last position of a character of C string.
size_type find_last_of (_CharT __c, size_type __pos=npos) const noexcept
Find last position of a character.
reference front ()
const_reference front () const noexcept
allocator_type get_allocator () const noexcept
Return copy of allocator used to construct this string.
void insert (iterator __p, size_type __n, _CharT __c)
Insert multiple characters.
template<class _InputIterator > void insert (iterator __p, _InputIterator __beg, _InputIterator __end)
Insert a range of characters.
void insert (iterator __p, initializer_list< _CharT > __l)
Insert an initializer_list of characters.
basic_string & insert (size_type __pos1, const basic_string &__str)
Insert value of a string.
basic_string & insert (size_type __pos1, const basic_string &__str, size_type __pos2, size_type __n=npos)
Insert a substring.
basic_string & insert (size_type __pos, const _CharT *__s, size_type __n)
Insert a C substring.
basic_string & insert (size_type __pos, const _CharT *__s)
Insert a C string.
basic_string & insert (size_type __pos, size_type __n, _CharT __c)
Insert multiple characters.
iterator insert (iterator __p, _CharT __c)
Insert one character.
size_type length () const noexcept
Returns the number of characters in the string, not including any null-termination.
size_type max_size () const noexcept
Returns the size() of the largest possible string.
basic_string & operator+= (const basic_string &__str)
Append a string to this string.
basic_string & operator+= (const _CharT *__s)
Append a C string.
basic_string & operator+= (_CharT __c)
Append a character.
basic_string & operator+= (initializer_list< _CharT > __l)
Append an initializer_list of characters.
basic_string & operator= (const basic_string &__str)
Assign the value of str to this string.
basic_string & operator= (const _CharT *__s)
Copy contents of s into this string.
basic_string & operator= (_CharT __c)
Set value to string of length 1.
basic_string & operator= (basic_string &&__str)
Move assign the value of str to this string.
basic_string & operator= (initializer_list< _CharT > __l)
Set value to string constructed from initializer list.
const_reference operator[] (size_type __pos) const noexcept
Subscript access to the data contained in the string.
reference operator[] (size_type __pos)
Subscript access to the data contained in the string.
void pop_back ()
Remove the last character.
void push_back (_CharT __c)
Append a single character.
reverse_iterator rbegin ()
const_reverse_iterator rbegin () const noexcept
reverse_iterator rend ()
const_reverse_iterator rend () const noexcept
basic_string & replace (size_type __pos, size_type __n, const basic_string &__str)
Replace characters with value from another string.
basic_string & replace (size_type __pos1, size_type __n1, const basic_string &__str, size_type __pos2, size_type __n2=npos)
Replace characters with value from another string.
basic_string & replace (size_type __pos, size_type __n1, const _CharT *__s, size_type __n2)
Replace characters with value of a C substring.
basic_string & replace (size_type __pos, size_type __n1, const _CharT *__s)
Replace characters with value of a C string.
basic_string & replace (size_type __pos, size_type __n1, size_type __n2, _CharT __c)
Replace characters with multiple characters.
basic_string & replace (iterator __i1, iterator __i2, const basic_string &__str)
Replace range of characters with string.
basic_string & replace (iterator __i1, iterator __i2, const _CharT *__s, size_type __n)
Replace range of characters with C substring.
basic_string & replace (iterator __i1, iterator __i2, const _CharT *__s)
Replace range of characters with C string.
basic_string & replace (iterator __i1, iterator __i2, size_type __n, _CharT __c)
Replace range of characters with multiple characters.
template<class _InputIterator > basic_string & replace (iterator __i1, iterator __i2, _InputIterator __k1, _InputIterator __k2)
Replace range of characters with range.
basic_string & replace (iterator __i1, iterator __i2, _CharT *__k1, _CharT *__k2)
basic_string & replace (iterator __i1, iterator __i2, const _CharT *__k1, const _CharT *__k2)
basic_string & replace (iterator __i1, iterator __i2, iterator __k1, iterator __k2)
basic_string & replace (iterator __i1, iterator __i2, const_iterator __k1, const_iterator __k2)
basic_string & replace (iterator __i1, iterator __i2, initializer_list< _CharT > __l)
Replace range of characters with initializer_list.
void reserve (size_type __res_arg=0)
Attempt to preallocate enough memory for specified number of characters.
void resize (size_type __n, _CharT __c)
Resizes the string to the specified number of characters.
void resize (size_type __n)
Resizes the string to the specified number of characters.
size_type rfind (const basic_string &__str, size_type __pos=npos) const noexcept
Find last position of a string.
size_type rfind (const _CharT *__s, size_type __pos, size_type __n) const noexcept
Find last position of a C substring.
size_type rfind (const _CharT *__s, size_type __pos=npos) const noexcept
Find last position of a C string.
size_type rfind (_CharT __c, size_type __pos=npos) const noexcept
Find last position of a character.
void shrink_to_fit () noexcept
A non-binding request to reduce capacity() to size().
size_type size () const noexcept
Returns the number of characters in the string, not including any null-termination.
basic_string substr (size_type __pos=0, size_type __n=npos) const
Get a substring.
void swap (basic_string &__s)
Swap contents with another string.
static const size_type npos
Value returned by various member functions when they fail.
Template Parameters:
Meets the requirements of a container, a reversible container, and a sequence. Of the optional sequence requirements, only push_back, at, and array access are supported.
Todo
Documentation? What's that? Nathan Myers ncm@cantrip.org.
A string looks like this:
[_Rep] _M_length [basic_string<char_type>] _M_capacity _M_dataplus _M_refcount _M_p ----------------> unnamed array of char_type
Where the _M_p points to the first character in the string, and you cast it to a pointer-to-_Rep and subtract 1 to get a pointer to the header.
This approach has the enormous advantage that a string object requires only one allocation. All the ugliness is confined within a single pair of inline functions, which each compile to a single add instruction: _Rep::_M_data(), and string::_M_rep(); and the allocation function which gets a block of raw bytes and with room enough and constructs a _Rep object at the front.
The reason you want _M_data pointing to the character array and not the _Rep is so that the debugger can see the string contents. (Probably we should add a non-inline member to get the _Rep for the debugger to use, so users can check the actual string length.)
Note that the _Rep object is a POD so that you can have a static empty string _Rep object already constructed before static constructors have run. The reference-count encoding is chosen so that a 0 indicates one reference, so you never try to destroy the empty-string _Rep object.
All but the last paragraph is considered pretty conventional for a C++ string implementation.
Definition at line 3104 of file basic_string.h.
Default constructor creates an empty string.
Definition at line 3489 of file basic_string.h.
Referenced by std::basic_string< char >::substr().
Construct an empty string using allocator a.
Definition at line 618 of file basic_string.tcc.
Construct string with copy of value of str.
Parameters:
Definition at line 610 of file basic_string.tcc.
Construct string as copy of a substring.
Parameters:
Definition at line 624 of file basic_string.tcc.
Construct string as copy of a substring.
Parameters:
Definition at line 634 of file basic_string.tcc.
Construct string as copy of a substring.
Parameters:
Definition at line 644 of file basic_string.tcc.
Construct string initialized by a character array.
Parameters:
NB: __s must have at least __n characters, '\0' has no special meaning.
Definition at line 656 of file basic_string.tcc.
Construct string as copy of a C string.
Parameters:
Definition at line 663 of file basic_string.tcc.
Construct string as multiple characters.
Parameters:
Definition at line 670 of file basic_string.tcc.
Move construct string.
Parameters:
The newly-created string contains the exact contents of __str. __str is a valid, but unspecified string.
Definition at line 3571 of file basic_string.h.
Construct string from an initializer list.
Parameters:
Definition at line 685 of file basic_string.tcc.
Construct string as copy of a range.
Parameters:
Definition at line 678 of file basic_string.tcc.
Destroy the string instance.
Definition at line 3639 of file basic_string.h.
Append a string to this string.
Parameters:
Returns:
Definition at line 775 of file basic_string.tcc.
Referenced by std::basic_string< char >::append(), and std::basic_string< char >::operator+=().
Append a substring.
Parameters:
Returns:
Exceptions:
This function appends __n characters from __str starting at __pos to this string. If __n is is larger than the number of available characters in __str, the remainder of __str is appended.
Definition at line 792 of file basic_string.tcc.
Append a C substring.
Parameters:
Returns:
Definition at line 748 of file basic_string.tcc.
Append a C string.
Parameters:
Returns:
Definition at line 4174 of file basic_string.h.
Append multiple characters.
Parameters:
Returns:
Appends __n copies of __c to this string.
Definition at line 731 of file basic_string.tcc.
Append an initializer_list of characters.
Parameters:
Returns:
Definition at line 4198 of file basic_string.h.
Append a range of characters.
Parameters:
Returns:
Appends characters in the range [__first,__last) to this string.
Definition at line 4212 of file basic_string.h.
Set value to contents of another string.
Parameters:
Returns:
Definition at line 693 of file basic_string.tcc.
Referenced by std::basic_string< char >::assign(), std::basic_string< char >::operator=(), and std::basic_stringbuf< _CharT, _Traits, _Alloc >::str().
Set value to contents of another string.
Parameters:
Returns:
This function sets this string to the exact contents of __str. __str is a valid, but unspecified string.
Definition at line 4281 of file basic_string.h.
Set value to a substring of a string.
Parameters:
Returns:
Exceptions:
This function sets this string to the substring of __str consisting of __n characters at __pos. If __n is is larger than the number of available characters in __str, the remainder of __str is used.
Definition at line 4302 of file basic_string.h.
Set value to a C substring.
Parameters:
Returns:
This function sets the value of this string to the first __n characters of __s. If __n is is larger than the number of available characters in __s, the remainder of __s is used.
Definition at line 709 of file basic_string.tcc.
Set value to contents of a C string.
Parameters:
Returns:
This function sets the value of this string to the value of __s. The data is copied, so there is no dependence on __s once the function returns.
Definition at line 4330 of file basic_string.h.
Set value to multiple characters.
Parameters:
Returns:
This function sets the value of this string to __n copies of character __c.
Definition at line 4346 of file basic_string.h.
Set value to a range of characters.
Parameters:
Returns:
Sets value of string to characters in the range [__first,__last).
Definition at line 4359 of file basic_string.h.
Set value to an initializer_list of characters.
Parameters:
Returns:
Definition at line 4369 of file basic_string.h.
Provides access to the data contained in the string.
Parameters:
Returns:
Exceptions:
This function provides for safer data access. The parameter is first checked that it is in the range of the string. The function throws out_of_range if the check fails.
Definition at line 4002 of file basic_string.h.
Provides access to the data contained in the string.
Parameters:
Returns:
Exceptions:
This function provides for safer data access. The parameter is first checked that it is in the range of the string. The function throws out_of_range if the check fails. Success results in unsharing the string.
Definition at line 4024 of file basic_string.h.
Definition at line 4063 of file basic_string.h.
Definition at line 4074 of file basic_string.h.
Definition at line 3725 of file basic_string.h.
Referenced by std::basic_string< char >::crend(), std::regex_match(), std::regex_replace(), std::regex_search(), and std::basic_string< char >::rend().
Definition at line 3736 of file basic_string.h.
Return const pointer to null-terminated contents. This is a handle to internal data. Do not modify or dire things may happen.
Definition at line 5128 of file basic_string.h.
Referenced by std::collate< _CharT >::do_compare(), std::money_get< _CharT, _InIter >::do_get(), std::num_get< _CharT, _InIter >::do_get(), std::collate< _CharT >::do_transform(), std::basic_filebuf< char_type, traits_type >::open(), and std::regex_replace().
Definition at line 3898 of file basic_string.h.
Referenced by std::basic_string< char >::push_back(), and std::basic_string< char >::shrink_to_fit().
Definition at line 3800 of file basic_string.h.
Definition at line 3808 of file basic_string.h.
Definition at line 3926 of file basic_string.h.
Referenced by std::basic_stringbuf< _CharT, _Traits, _Alloc >::setbuf().
Compare to a string.
Parameters:
Returns:
Returns an integer < 0 if this string is ordered before __str, 0 if their values are equivalent, or > 0 if this string is ordered after __str. Determines the effective length rlen of the strings to compare as the smallest of size() and str.size(). The function then compares the two strings by calling traits::compare(data(), str.data(),rlen). If the result of the comparison is nonzero returns it, otherwise the shorter one is ordered first.
Definition at line 5684 of file basic_string.h.
Referenced by std::sub_match< _Bi_iter >::compare().
Compare substring to a string.
Parameters:
Returns:
Form the substring of this string from the __n characters starting at __pos. Returns an integer < 0 if the substring is ordered before __str, 0 if their values are equivalent, or > 0 if the substring is ordered after __str. Determines the effective length rlen of the strings to compare as the smallest of the length of the substring and __str.size(). The function then compares the two strings by calling traits::compare(substring.data(),str.data(),rlen). If the result of the comparison is nonzero returns it, otherwise the shorter one is ordered first.
Definition at line 1385 of file basic_string.tcc.
Compare substring to a substring.
Parameters:
Returns:
Form the substring of this string from the __n1 characters starting at __pos1. Form the substring of __str from the __n2 characters starting at __pos2. Returns an integer < 0 if this substring is ordered before the substring of __str, 0 if their values are equivalent, or > 0 if this substring is ordered after the substring of __str. Determines the effective length rlen of the strings to compare as the smallest of the lengths of the substrings. The function then compares the two strings by calling traits::compare(substring.data(),str.substr(pos2,n2).data(),rlen). If the result of the comparison is nonzero returns it, otherwise the shorter one is ordered first.
Definition at line 1400 of file basic_string.tcc.
Compare to a C string.
Parameters:
Returns:
Returns an integer < 0 if this string is ordered before __s, 0 if their values are equivalent, or > 0 if this string is ordered after __s. Determines the effective length rlen of the strings to compare as the smallest of size() and the length of a string constructed from __s. The function then compares the two strings by calling traits::compare(data(),s,rlen). If the result of the comparison is nonzero returns it, otherwise the shorter one is ordered first.
Definition at line 1418 of file basic_string.tcc.
Compare substring to a C string.
Parameters:
Returns:
Form the substring of this string from the __n1 characters starting at pos. Returns an integer < 0 if the substring is ordered before __s, 0 if their values are equivalent, or > 0 if the substring is ordered after __s. Determines the effective length rlen of the strings to compare as the smallest of the length of the substring and the length of a string constructed from __s. The function then compares the two string by calling traits::compare(substring.data(),__s,rlen). If the result of the comparison is nonzero returns it, otherwise the shorter one is ordered first.
Definition at line 1433 of file basic_string.tcc.
Compare substring against a character array.
Parameters:
Returns:
Form the substring of this string from the __n1 characters starting at __pos. Form a string from the first __n2 characters of __s. Returns an integer < 0 if this substring is ordered before the string from __s, 0 if their values are equivalent, or > 0 if this substring is ordered after the string from __s. Determines the effective length rlen of the strings to compare as the smallest of the length of the substring and __n2. The function then compares the two strings by calling traits::compare(substring.data(),s,rlen). If the result of the comparison is nonzero returns it, otherwise the shorter one is ordered first.
NB: s must have at least n2 characters, '\0' has no special meaning.
Definition at line 1449 of file basic_string.tcc.
Copy substring into C string.
Parameters:
Returns:
Exceptions:
Copies up to __n characters starting at __pos into the C string __s. If __pos is greater than size(), out_of_range is thrown.
Definition at line 1143 of file basic_string.tcc.
Definition at line 3817 of file basic_string.h.
Definition at line 3826 of file basic_string.h.
Return const pointer to contents. This is a pointer to internal data. It is undefined to modify the contents through the returned pointer. To get a pointer that allows modifying the contents use &str[0] instead, (or in C++17 the non-const str.data() overload).
Definition at line 5140 of file basic_string.h.
Referenced by std::basic_regex< _Ch_type, _Rx_traits >::assign(), std::basic_string< char >::compare(), std::collate< _CharT >::do_compare(), std::collate< _CharT >::do_transform(), std::match_results< _Bi_iter >::format(), std::wstring_convert< _Codecvt, _Elem, _Wide_alloc, _Byte_alloc >::from_bytes(), std::operator<(), std::operator==(), std::basic_stringbuf< _CharT, _Traits, _Alloc >::str(), std::wstring_convert< _Codecvt, _Elem, _Wide_alloc, _Byte_alloc >::to_bytes(), and std::regex_traits< _CharType >::transform().
Definition at line 3948 of file basic_string.h.
Definition at line 3744 of file basic_string.h.
Referenced by std::basic_string< char >::crbegin(), std::basic_string< char >::rbegin(), std::regex_match(), std::regex_replace(), and std::regex_search().
Definition at line 3755 of file basic_string.h.
Remove characters.
Parameters:
Returns:
Exceptions:
Removes __n characters from this string starting at __pos. The length of the string is reduced by __n. If there are < __n characters to remove, the remainder of the string is truncated. If __p is beyond end of string, out_of_range is thrown. The value of the string doesn't change if an error is thrown.
Definition at line 4632 of file basic_string.h.
Remove one character.
Parameters:
Returns:
Removes the character at __position from this string. The value of the string doesn't change if an error is thrown.
Definition at line 4648 of file basic_string.h.
Remove a range of characters.
Parameters:
Returns:
Removes the characters in the range [first,last) from this string. The value of the string doesn't change if an error is thrown.
Definition at line 841 of file basic_string.tcc.
Find position of a C substring.
Parameters:
Returns:
Starting from __pos, searches forward for the first __n characters in __s within this string. If found, returns the index where it begins. If not found, returns npos.
Definition at line 1188 of file basic_string.tcc.
Referenced by std::basic_string< char >::find(), and std::basic_string< char >::find_first_of().
Find position of a string.
Parameters:
Returns:
Starting from __pos, searches forward for value of __str within this string. If found, returns the index where it begins. If not found, returns npos.
Definition at line 5192 of file basic_string.h.
Find position of a C string.
Parameters:
Returns:
Starting from __pos, searches forward for the value of __s within this string. If found, returns the index where it begins. If not found, returns npos.
Definition at line 5207 of file basic_string.h.
Find position of a character.
Parameters:
Returns:
Starting from __pos, searches forward for __c within this string. If found, returns the index where it was found. If not found, returns npos.
Definition at line 1224 of file basic_string.tcc.
Find position of a character not in string.
Parameters:
Returns:
Starting from __pos, searches forward for a character not contained in __str within this string. If found, returns the index where it was found. If not found, returns npos.
Definition at line 5500 of file basic_string.h.
Referenced by std::basic_string< char >::find_first_not_of().
Find position of a character not in C substring.
Parameters:
Returns:
Starting from __pos, searches forward for a character not contained in the first __n characters of __s within this string. If found, returns the index where it was found. If not found, returns npos.
Definition at line 1319 of file basic_string.tcc.
Find position of a character not in C string.
Parameters:
Returns:
Starting from __pos, searches forward for a character not contained in __s within this string. If found, returns the index where it was found. If not found, returns npos.
Definition at line 5531 of file basic_string.h.
Find position of a different character.
Parameters:
Returns:
Starting from __pos, searches forward for a character other than __c within this string. If found, returns the index where it was found. If not found, returns npos.
Definition at line 1332 of file basic_string.tcc.
Find position of a character of string.
Parameters:
Returns:
Starting from __pos, searches forward for one of the characters of __str within this string. If found, returns the index where it was found. If not found, returns npos.
Definition at line 5333 of file basic_string.h.
Referenced by std::basic_string< char >::find_first_of().
Find position of a character of C substring.
Parameters:
Returns:
Starting from __pos, searches forward for one of the first __n characters of __s within this string. If found, returns the index where it was found. If not found, returns npos.
Definition at line 1281 of file basic_string.tcc.
Find position of a character of C string.
Parameters:
Returns:
Starting from __pos, searches forward for one of the characters of __s within this string. If found, returns the index where it was found. If not found, returns npos.
Definition at line 5364 of file basic_string.h.
Find position of a character.
Parameters:
Returns:
Starting from __pos, searches forward for the character __c within this string. If found, returns the index where it was found. If not found, returns npos.
Note: equivalent to find(__c, __pos).
Definition at line 5384 of file basic_string.h.
Find last position of a character not in string.
Parameters:
Returns:
Starting from __pos, searches backward for a character not contained in __str within this string. If found, returns the index where it was found. If not found, returns npos.
Definition at line 5582 of file basic_string.h.
Referenced by std::basic_string< char >::find_last_not_of().
Find last position of a character not in C substring.
Parameters:
Returns:
Starting from __pos, searches backward for a character not contained in the first __n characters of __s within this string. If found, returns the index where it was found. If not found, returns npos.
Definition at line 1343 of file basic_string.tcc.
Find last position of a character not in C string.
Parameters:
Returns:
Starting from __pos, searches backward for a character not contained in __s within this string. If found, returns the index where it was found. If not found, returns npos.
Definition at line 5613 of file basic_string.h.
Find last position of a different character.
Parameters:
Returns:
Starting from __pos, searches backward for a character other than __c within this string. If found, returns the index where it was found. If not found, returns npos.
Definition at line 1365 of file basic_string.tcc.
Find last position of a character of string.
Parameters:
Returns:
Starting from __pos, searches backward for one of the characters of __str within this string. If found, returns the index where it was found. If not found, returns npos.
Definition at line 5417 of file basic_string.h.
Referenced by std::basic_string< char >::find_last_of().
Find last position of a character of C substring.
Parameters:
Returns:
Starting from __pos, searches backward for one of the first __n characters of __s within this string. If found, returns the index where it was found. If not found, returns npos.
Definition at line 1297 of file basic_string.tcc.
Find last position of a character of C string.
Parameters:
Returns:
Starting from __pos, searches backward for one of the characters of __s within this string. If found, returns the index where it was found. If not found, returns npos.
Definition at line 5448 of file basic_string.h.
Find last position of a character.
Parameters:
Returns:
Starting from __pos, searches backward for __c within this string. If found, returns the index where it was found. If not found, returns npos.
Note: equivalent to rfind(__c, __pos).
Definition at line 5468 of file basic_string.h.
Definition at line 4041 of file basic_string.h.
Definition at line 4052 of file basic_string.h.
Return copy of allocator used to construct this string.
Definition at line 5162 of file basic_string.h.
Referenced by std::basic_string< char >::assign(), std::basic_string< char >::basic_string(), std::basic_string< char >::clear(), std::wstring_convert< _Codecvt, _Elem, _Wide_alloc, _Byte_alloc >::from_bytes(), std::basic_stringbuf< _CharT, _Traits, _Alloc >::str(), std::basic_string< char >::swap(), std::wstring_convert< _Codecvt, _Elem, _Wide_alloc, _Byte_alloc >::to_bytes(), and std::basic_string< char >::~basic_string().
Insert multiple characters.
Parameters:
Exceptions:
Inserts __n copies of character __c starting at the position referenced by iterator __p. If adding characters causes the length to exceed max_size(), length_error is thrown. The value of the string doesn't change if an error is thrown.
Definition at line 4419 of file basic_string.h.
Referenced by std::basic_string< char >::insert().
Insert a range of characters.
Parameters:
Exceptions:
Inserts characters in range [__beg,__end). If adding characters causes the length to exceed max_size(), length_error is thrown. The value of the string doesn't change if an error is thrown.
Definition at line 4436 of file basic_string.h.
Insert an initializer_list of characters.
Parameters:
Exceptions:
Definition at line 4447 of file basic_string.h.
Insert value of a string.
Parameters:
Returns:
Exceptions:
Inserts value of __str starting at __pos1. If adding characters causes the length to exceed max_size(), length_error is thrown. The value of the string doesn't change if an error is thrown.
Definition at line 4467 of file basic_string.h.
Insert a substring.
Parameters:
Returns:
Exceptions:
Starting at pos1, insert __n character of __str beginning with __pos2. If adding characters causes the length to exceed max_size(), length_error is thrown. If __pos1 is beyond the end of this string or __pos2 is beyond the end of __str, out_of_range is thrown. The value of the string doesn't change if an error is thrown.
Definition at line 4489 of file basic_string.h.
Insert a C substring.
Parameters:
Returns:
Exceptions:
Inserts the first __n characters of __s starting at __pos. If adding characters causes the length to exceed max_size(), length_error is thrown. If __pos is beyond end(), out_of_range is thrown. The value of the string doesn't change if an error is thrown.
Definition at line 810 of file basic_string.tcc.
Insert a C string.
Parameters:
Returns:
Exceptions:
Inserts the first n characters of __s starting at __pos. If adding characters causes the length to exceed max_size(), length_error is thrown. If __pos is beyond end(), out_of_range is thrown. The value of the string doesn't change if an error is thrown.
Definition at line 4530 of file basic_string.h.
Insert multiple characters.
Parameters:
Returns:
Exceptions:
Inserts __n copies of character __c starting at index __pos. If adding characters causes the length to exceed max_size(), length_error is thrown. If __pos > length(), out_of_range is thrown. The value of the string doesn't change if an error is thrown.
Definition at line 4553 of file basic_string.h.
Insert one character.
Parameters:
Returns:
Exceptions:
Inserts character __c at position referenced by __p. If adding character causes the length to exceed max_size(), length_error is thrown. If __p is beyond end of string, out_of_range is thrown. The value of the string doesn't change if an error is thrown.
Definition at line 4571 of file basic_string.h.
Returns the number of characters in the string, not including any null-termination.
Definition at line 3841 of file basic_string.h.
Referenced by std::collate< _CharT >::do_compare(), and std::collate< _CharT >::do_transform().
Returns the size() of the largest possible string.
Definition at line 3846 of file basic_string.h.
Append a string to this string.
Parameters:
Returns:
Definition at line 4088 of file basic_string.h.
Append a C string.
Parameters:
Returns:
Definition at line 4097 of file basic_string.h.
Append a character.
Parameters:
Returns:
Definition at line 4106 of file basic_string.h.
Append an initializer_list of characters.
Parameters:
Returns:
Definition at line 4119 of file basic_string.h.
Assign the value of str to this string.
Parameters:
Definition at line 3647 of file basic_string.h.
Copy contents of s into this string.
Parameters:
Definition at line 3655 of file basic_string.h.
Set value to string of length 1.
Parameters:
Assigning to a character makes this string length 1 and (*this)[0] == c.
Definition at line 3666 of file basic_string.h.
Move assign the value of str to this string.
Parameters:
The contents of str are moved into this string (without copying). str is a valid, but unspecified string.
Definition at line 3682 of file basic_string.h.
Set value to string constructed from initializer list.
Parameters:
Definition at line 3694 of file basic_string.h.
Subscript access to the data contained in the string.
Parameters:
Returns:
This operator allows for easy, array-style, data access. Note that data access with this operator is unchecked and out_of_range lookups are not defined. (For checked lookups see at().)
Definition at line 3963 of file basic_string.h.
Subscript access to the data contained in the string.
Parameters:
Returns:
This operator allows for easy, array-style, data access. Note that data access with this operator is unchecked and out_of_range lookups are not defined. (For checked lookups see at().) Unshares the string.
Definition at line 3980 of file basic_string.h.
Remove the last character. The string must be non-empty.
Definition at line 4677 of file basic_string.h.
Append a single character.
Parameters:
Definition at line 4253 of file basic_string.h.
Referenced by std::basic_string< char >::operator+=().
Definition at line 3764 of file basic_string.h.
Definition at line 3773 of file basic_string.h.
Definition at line 3782 of file basic_string.h.
Definition at line 3791 of file basic_string.h.
Replace characters with value from another string.
Parameters:
Returns:
Exceptions:
Removes the characters in the range [__pos,__pos+__n) from this string. In place, the value of __str is inserted. If __pos is beyond end of string, out_of_range is thrown. If the length of the result exceeds max_size(), length_error is thrown. The value of the string doesn't change if an error is thrown.
Definition at line 4702 of file basic_string.h.
Referenced by std::basic_string< char >::append(), std::basic_string< char >::assign(), std::basic_string< char >::insert(), and std::basic_string< char >::replace().
Replace characters with value from another string.
Parameters:
Returns:
Exceptions:
Removes the characters in the range [__pos1,__pos1 + n) from this string. In place, the value of __str is inserted. If __pos is beyond end of string, out_of_range is thrown. If the length of the result exceeds max_size(), length_error is thrown. The value of the string doesn't change if an error is thrown.
Definition at line 4724 of file basic_string.h.
Replace characters with value of a C substring.
Parameters:
Returns:
Exceptions:
Removes the characters in the range [__pos,__pos + __n1) from this string. In place, the first __n2 characters of __s are inserted, or all of __s if __n2 is too large. If __pos is beyond end of string, out_of_range is thrown. If the length of result exceeds max_size(), length_error is thrown. The value of the string doesn't change if an error is thrown.
Definition at line 864 of file basic_string.tcc.
Replace characters with value of a C string.
Parameters:
Returns:
Exceptions:
Removes the characters in the range [__pos,__pos + __n1) from this string. In place, the characters of __s are inserted. If __pos is beyond end of string, out_of_range is thrown. If the length of result exceeds max_size(), length_error is thrown. The value of the string doesn't change if an error is thrown.
Definition at line 4769 of file basic_string.h.
Replace characters with multiple characters.
Parameters:
Returns:
Exceptions:
Removes the characters in the range [pos,pos + n1) from this string. In place, __n2 copies of __c are inserted. If __pos is beyond end of string, out_of_range is thrown. If the length of result exceeds max_size(), length_error is thrown. The value of the string doesn't change if an error is thrown.
Definition at line 4793 of file basic_string.h.
Replace range of characters with string.
Parameters:
Returns:
Exceptions:
Removes the characters in the range [__i1,__i2). In place, the value of __str is inserted. If the length of result exceeds max_size(), length_error is thrown. The value of the string doesn't change if an error is thrown.
Definition at line 4811 of file basic_string.h.
Replace range of characters with C substring.
Parameters:
Returns:
Exceptions:
Removes the characters in the range [__i1,__i2). In place, the first __n characters of __s are inserted. If the length of result exceeds max_size(), length_error is thrown. The value of the string doesn't change if an error is thrown.
Definition at line 4830 of file basic_string.h.
Replace range of characters with C string.
Parameters:
Returns:
Exceptions:
Removes the characters in the range [__i1,__i2). In place, the characters of __s are inserted. If the length of result exceeds max_size(), length_error is thrown. The value of the string doesn't change if an error is thrown.
Definition at line 4851 of file basic_string.h.
Replace range of characters with multiple characters.
Parameters:
Returns:
Exceptions:
Removes the characters in the range [__i1,__i2). In place, __n copies of __c are inserted. If the length of result exceeds max_size(), length_error is thrown. The value of the string doesn't change if an error is thrown.
Definition at line 4872 of file basic_string.h.
Replace range of characters with range.
Parameters:
Returns:
Exceptions:
Removes the characters in the range [__i1,__i2). In place, characters in the range [__k1,__k2) are inserted. If the length of result exceeds max_size(), length_error is thrown. The value of the string doesn't change if an error is thrown.
Definition at line 4896 of file basic_string.h.
Replace range of characters with initializer_list.
Parameters:
Returns:
Exceptions:
Removes the characters in the range [__i1,__i2). In place, characters in the range [__k1,__k2) are inserted. If the length of result exceeds max_size(), length_error is thrown. The value of the string doesn't change if an error is thrown.
Definition at line 4965 of file basic_string.h.
Attempt to preallocate enough memory for specified number of characters.
Parameters:
Exceptions:
This function attempts to reserve enough memory for the string to hold the specified number of characters. If the number requested is more than max_size(), length_error is thrown.
The advantage of this function is that if optimal code is a necessity and the user can determine the string length that will be required, the user can reserve the memory in advance, and thus prevent a possible reallocation of memory and copying of string data.
Definition at line 952 of file basic_string.tcc.
Referenced by std::num_get< _CharT, _InIter >::do_get(), std::tr2::operator>>(), std::operator>>(), std::basic_string< char >::push_back(), and std::basic_string< char >::shrink_to_fit().
Resizes the string to the specified number of characters.
Parameters:
This function will resize the string to the specified number of characters. If the number is smaller than the string's current size the string is truncated, otherwise the string is extended and new elements are set to __c.
Definition at line 1090 of file basic_string.tcc.
Referenced by std::money_get< _CharT, _InIter >::do_get(), and std::basic_string< char >::resize().
Resizes the string to the specified number of characters.
Parameters:
This function will resize the string to the specified length. If the new size is smaller than the string's current size the string is truncated, otherwise the string is extended and new characters are default-constructed. For basic types such as char, this means setting them to 0.
Definition at line 3873 of file basic_string.h.
Find last position of a string.
Parameters:
Returns:
Starting from __pos, searches backward for value of __str within this string. If found, returns the index where it begins. If not found, returns npos.
Definition at line 5254 of file basic_string.h.
Referenced by std::basic_string< char >::find_last_of(), and std::basic_string< char >::rfind().
Find last position of a C substring.
Parameters:
Returns:
Starting from __pos, searches backward for the first __n characters in __s within this string. If found, returns the index where it begins. If not found, returns npos.
Definition at line 1242 of file basic_string.tcc.
Find last position of a C string.
Parameters:
Returns:
Starting from __pos, searches backward for the value of __s within this string. If found, returns the index where it begins. If not found, returns npos.
Definition at line 5285 of file basic_string.h.
Find last position of a character.
Parameters:
Returns:
Starting from __pos, searches backward for __c within this string. If found, returns the index where it was found. If not found, returns npos.
Definition at line 1264 of file basic_string.tcc.
A non-binding request to reduce capacity() to size().
Definition at line 3879 of file basic_string.h.
Returns the number of characters in the string, not including any null-termination.
Definition at line 3835 of file basic_string.h.
Referenced by std::basic_regex< _Ch_type, _Rx_traits >::assign(), std::basic_string< char >::assign(), std::basic_string< char >::at(), std::basic_string< char >::cend(), std::basic_string< char >::compare(), std::tr2::dynamic_bitset< _WordT, _Alloc >::dynamic_bitset(), std::basic_string< char >::empty(), std::basic_string< char >::end(), std::match_results< _Bi_iter >::format(), std::wstring_convert< _Codecvt, _Elem, _Wide_alloc, _Byte_alloc >::from_bytes(), std::operator<(), std::operator==(), std::basic_string< char >::push_back(), std::basic_string< char >::shrink_to_fit(), std::basic_stringbuf< _CharT, _Traits, _Alloc >::str(), std::wstring_convert< _Codecvt, _Elem, _Wide_alloc, _Byte_alloc >::to_bytes(), and std::regex_traits< _CharType >::transform().
Get a substring.
Parameters:
Returns:
Exceptions:
Construct and return a new string using the __n characters starting at __pos. If the string is too short, use the remainder of the characters. If __pos is beyond the end of the string, out_of_range is thrown.
Definition at line 5665 of file basic_string.h.
Swap contents with another string.
Parameters:
Exchanges the contents of this string with that of __s in constant time.
Definition at line 969 of file basic_string.tcc.
Referenced by std::basic_string< char >::assign(), and std::basic_string< char >::operator=().
Value returned by various member functions when they fail.
Definition at line 3306 of file basic_string.h.
Generated automatically by Doxygen for libstdc++ from the source code.