📄 string
字号:
input_iterator_tag) { _M_allocate_block(8); construct(_M_finish); __STL_TRY { append(__f, __l); } __STL_UNWIND(destroy(_M_start, _M_finish + 1)); } template <class _ForwardIter> void _M_range_initialize(_ForwardIter __f, _ForwardIter __l, forward_iterator_tag) { typename iterator_traits<_ForwardIter>::difference_type __n = distance(__f, __l); _M_allocate_block(__n + 1); _M_finish = uninitialized_copy(__f, __l, _M_start); _M_terminate_string(); } template <class _InputIter> void _M_range_initialize(_InputIter __f, _InputIter __l) { typedef typename iterator_traits<_InputIter>::iterator_category _Category; _M_range_initialize(__f, __l, _Category()); } template <class _Integer> void _M_initialize_dispatch(_Integer __n, _Integer __x, __true_type) { _M_allocate_block(__n + 1); _M_finish = uninitialized_fill_n(_M_start, __n, __x); _M_terminate_string(); } template <class _InputIter> void _M_initialize_dispatch(_InputIter __f, _InputIter __l, __false_type) { _M_range_initialize(__f, __l); } public: // Iterators. iterator begin() { return _M_start; } iterator end() { return _M_finish; } const_iterator begin() const { return _M_start; } const_iterator end() const { return _M_finish; } reverse_iterator rbegin() { return reverse_iterator(_M_finish); } reverse_iterator rend() { return reverse_iterator(_M_start); } const_reverse_iterator rbegin() const { return const_reverse_iterator(_M_finish); } const_reverse_iterator rend() const { return const_reverse_iterator(_M_start); }public: // Size, capacity, etc. size_type size() const { return _M_finish - _M_start; } size_type length() const { return size(); }#ifdef __STL_USE_NAMESPACES using _Base::max_size;#endif /* __STL_USE_NAMESPACES */ void resize(size_type __n, _CharT __c = _CharT()) { if (__n <= size()) erase(begin() + __n, end()); else append(__n - size(), __c); } void reserve(size_type = 0); size_type capacity() const { return (_M_end_of_storage - _M_start) - 1; } void clear() { if (!empty()) { _Traits::assign(*_M_start, _CharT()); destroy(_M_start+1, _M_finish+1); _M_finish = _M_start; } } bool empty() const { return _M_start == _M_finish; } public: // Element access. const_reference operator[](size_type __n) const { return *(_M_start + __n); } reference operator[](size_type __n) { return *(_M_start + __n); } const_reference at(size_type __n) const { if (__n >= size()) _M_throw_out_of_range(); return *(_M_start + __n); } reference at(size_type __n) { if (__n >= size()) _M_throw_out_of_range(); return *(_M_start + __n); }public: // Append, operator+=, push_back. basic_string& operator+=(const basic_string& __s) { return append(__s); } basic_string& operator+=(const _CharT* __s) { return append(__s); } basic_string& operator+=(_CharT __c) { push_back(__c); return *this; } basic_string& append(const basic_string& __s) { return append(__s.begin(), __s.end()); } basic_string& append(const basic_string& __s, size_type __pos, size_type __n) { if (__pos > __s.size()) _M_throw_out_of_range(); return append(__s.begin() + __pos, __s.begin() + __pos + min(__n, __s.size() - __pos)); } basic_string& append(const _CharT* __s, size_type __n) { return append(__s, __s+__n); } basic_string& append(const _CharT* __s) { return append(__s, __s + _Traits::length(__s)); } basic_string& append(size_type __n, _CharT __c); // Check to see if _InputIterator is an integer type. If so, then // it can't be an iterator. template <class _InputIter> basic_string& append(_InputIter __first, _InputIter __last) { typedef typename _Is_integer<_InputIter>::_Integral _Integral; return _M_append_dispatch(__first, __last, _Integral()); } void push_back(_CharT __c) { if (_M_finish + 1 == _M_end_of_storage) reserve(size() + max(size(), static_cast<size_type>(1))); construct(_M_finish + 1); _Traits::assign(*_M_finish, __c); ++_M_finish; } void pop_back() { _Traits::assign(*(_M_finish - 1), _CharT()); destroy(_M_finish); --_M_finish; }private: // Helper functions for append. template <class _InputIter> basic_string& append(_InputIter __f, _InputIter __l, input_iterator_tag); template <class _ForwardIter> basic_string& append(_ForwardIter __f, _ForwardIter __l, forward_iterator_tag); template <class _Integer> basic_string& _M_append_dispatch(_Integer __n, _Integer __x, __true_type) { return append((size_type) __n, (_CharT) __x); } template <class _InputIter> basic_string& _M_append_dispatch(_InputIter __f, _InputIter __l, __false_type) { typedef typename iterator_traits<_InputIter>::iterator_category _Category; return append(__f, __l, _Category()); }public: // Assign basic_string& assign(const basic_string& __s) { return assign(__s.begin(), __s.end()); } basic_string& assign(const basic_string& __s, size_type __pos, size_type __n) { if (__pos > __s.size()) _M_throw_out_of_range(); return assign(__s.begin() + __pos, __s.begin() + __pos + min(__n, __s.size() - __pos)); } basic_string& assign(const _CharT* __s, size_type __n) { return assign(__s, __s + __n); } basic_string& assign(const _CharT* __s) { return assign(__s, __s + _Traits::length(__s)); } basic_string& assign(size_type __n, _CharT __c); // Check to see if _InputIterator is an integer type. If so, then // it can't be an iterator. template <class _InputIter> basic_string& assign(_InputIter __first, _InputIter __last) { typedef typename _Is_integer<_InputIter>::_Integral _Integral; return _M_assign_dispatch(__first, __last, _Integral()); } basic_string& assign(const _CharT* __f, const _CharT* __l);private: // Helper functions for assign. template <class _Integer> basic_string& _M_assign_dispatch(_Integer __n, _Integer __x, __true_type) { return assign((size_type) __n, (_CharT) __x); } template <class _InputIter> basic_string& _M_assign_dispatch(_InputIter __f, _InputIter __l, __false_type);public: // Insert basic_string& insert(size_type __pos, const basic_string& __s) { if (__pos > size()) _M_throw_out_of_range(); if (size() > max_size() - __s.size()) _M_throw_length_error(); insert(_M_start + __pos, __s.begin(), __s.end()); return *this; } basic_string& insert(size_type __pos, const basic_string& __s, size_type __beg, size_type __n) { if (__pos > size() || __beg > __s.size()) _M_throw_out_of_range(); size_type __len = min(__n, __s.size() - __beg); if (size() > max_size() - __len) _M_throw_length_error(); insert(_M_start + __pos, __s.begin() + __beg, __s.begin() + __beg + __len); return *this; } basic_string& insert(size_type __pos, const _CharT* __s, size_type __n) { if (__pos > size()) _M_throw_out_of_range(); if (size() > max_size() - __n) _M_throw_length_error(); insert(_M_start + __pos, __s, __s + __n); return *this; } basic_string& insert(size_type __pos, const _CharT* __s) { if (__pos > size()) _M_throw_out_of_range(); size_type __len = _Traits::length(__s); if (size() > max_size() - __len) _M_throw_length_error(); insert(_M_start + __pos, __s, __s + __len); return *this; } basic_string& insert(size_type __pos, size_type __n, _CharT __c) { if (__pos > size()) _M_throw_out_of_range(); if (size() > max_size() - __n) _M_throw_length_error(); insert(_M_start + __pos, __n, __c); return *this; } iterator insert(iterator __p, _CharT __c) { if (__p == _M_finish) { push_back(__c); return _M_finish - 1; } else return _M_insert_aux(__p, __c); } void insert(iterator __p, size_t __n, _CharT __c); // Check to see if _InputIterator is an integer type. If so, then // it can't be an iterator. template <class _InputIter> void insert(iterator __p, _InputIter __first, _InputIter __last) { typedef typename _Is_integer<_InputIter>::_Integral _Integral; _M_insert_dispatch(__p, __first, __last, _Integral()); }private: // Helper functions for insert. template <class _InputIter> void insert(iterator __p, _InputIter, _InputIter, input_iterator_tag); template <class _ForwardIter> void insert(iterator __p, _ForwardIter, _ForwardIter, forward_iterator_tag); template <class _Integer> void _M_insert_dispatch(iterator __p, _Integer __n, _Integer __x, __true_type) { insert(__p, (size_type) __n, (_CharT) __x); } template <class _InputIter> void _M_insert_dispatch(iterator __p, _InputIter __first, _InputIter __last, __false_type) { typedef typename iterator_traits<_InputIter>::iterator_category _Category; insert(__p, __first, __last, _Category()); } iterator _M_insert_aux(iterator, _CharT); template <class _InputIterator> void _M_copy(_InputIterator __first, _InputIterator __last, iterator __result) { for ( ; __first != __last; ++__first, ++__result) _Traits::assign(*__result, *__first); } void _M_copy(const _CharT* __first, const _CharT* __last, _CharT* __result) { _Traits::copy(__result, __first, __last - __first); }public: // Erase. basic_string& erase(size_type __pos = 0, size_type __n = npos) { if (__pos > size()) _M_throw_out_of_range(); erase(_M_start + __pos, _M_start + __pos + min(__n, size() - __pos)); return *this; } iterator erase(iterator __position) { // The move includes the terminating _CharT(). _Traits::move(__position, __position + 1, _M_finish - __position); destroy(_M_finish); --_M_finish; return __position; } iterator erase(iterator __first, iterator __last) { if (__first != __last) { // The move includes the terminating _CharT(). _Traits::move(__first, __last, (_M_finish - __last) + 1); const iterator __new_finish = _M_finish - (__last - __first); destroy(__new_finish + 1, _M_finish + 1); _M_finish = __new_finish; } return __first; }public: // Replace. (Conceptually equivalent // to erase followed by insert.) basic_string& replace(size_type __pos, size_type __n, const basic_string& __s) { if (__pos > size()) _M_throw_out_of_range(); const size_type __len = min(__n, size() - __pos); if (size() - __len >= max_size() - __s.size()) _M_throw_length_error(); return replace(_M_start + __pos, _M_start + __pos + __len, __s.begin(), __s.end()); } basic_string& replace(size_type __pos1, size_type __n1, const basic_string& __s, size_type __pos2, size_type __n2) { if (__pos1 > size() || __pos2 > __s.size()) _M_throw_out_of_range(); const size_type __len1 = min(__n1, size() - __pos1); const size_type __len2 = min(__n2, __s.size() - __pos2); if (size() - __len1 >= max_size() - __len2) _M_throw_length_error(); return replace(_M_start + __pos1, _M_start + __pos1 + __len1, __s._M_start + __pos2, __s._M_start + __pos2 + __len2); } basic_string& replace(size_type __pos, size_type __n1, const _CharT* __s, size_type __n2) { if (__pos > size()) _M_throw_out_of_range(); const size_type __len = min(__n1, size() - __pos); if (__n2 > max_size() || size() - __len >= max_size() - __n2) _M_throw_length_error(); return replace(_M_start + __pos, _M_start + __pos + __len, __s, __s + __n2); } basic_string& replace(size_type __pos, size_type __n1, const _CharT* __s) { if (__pos > size()) _M_throw_out_of_range(); const size_type __len = min(__n1, size() - __pos); const size_type __n2 = _Traits::length(__s); if (__n2 > max_size() || size() - __len >= max_size() - __n2) _M_throw_length_error(); return replace(_M_start + __pos, _M_start + __pos + __len,
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -