亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? stl_string.c

?? 粗慥集成算法集合 ,并有詳細(xì)的文檔資料和測(cè)試數(shù)據(jù)處
?? C
?? 第 1 頁 / 共 3 頁
字號(hào):
/*
 *
 *
 * Copyright (c) 1994
 * Hewlett-Packard Company
 *
 * Copyright (c) 1996,1997
 * Silicon Graphics Computer Systems, Inc.
 *
 * Copyright (c) 1997
 * Moscow Center for SPARC Technology
 *
 * Copyright (c) 1999 
 * Boris Fomitchev
 *
 * This material is provided "as is", with absolutely no warranty expressed
 * or implied. Any use is at your own risk.
 *
 * Permission to use or copy this software for any purpose is hereby granted 
 * without fee, provided the above notices are retained on all copies.
 * Permission to modify the code and to distribute modified code is granted,
 * provided the above notices are retained, and a notice that the code was
 * modified is included with the above copyright notice.
 *
 */
#ifndef __STL_STRING_C
#define __STL_STRING_C


# if !defined (__STL_LINK_TIME_INSTANTIATION)
#  include <stl_string_fwd.c>
# endif

# if defined (__STL_USE_NEW_IOSTREAMS) && ! defined (__STLPORT_NEW_IOSTREAMS) && !defined (__STL_MSVC)
#  include <locale>
# endif

# if defined (__STL_USE_OWN_NAMESPACE) || !defined (__STL_USE_NATIVE_STRING)

#if defined(__sgi) && !defined(__GNUC__) && (_MIPS_SIM != _MIPS_SIM_ABI32)
#pragma set woff 1174
#pragma set woff 1375
#endif

# undef _Make_ptr
# if defined (__STL_DEBUG)
#  define _Make_ptr(__i)   __i._M_iterator
# else
#  define _Make_ptr(__i)   __i
# endif

# if defined (__STL_NESTED_TYPE_PARAM_BUG)
#  define __size_type__ size_t
#  define size_type size_t
#  if defined (__STL_DEBUG)
#   define __iterator__       _Vec_iter<_CharT, _Nonconst_traits<_CharT> >
#  else
#   define __iterator__  _CharT*
#  endif
#   define iterator      __iterator__
# else
#  define __size_type__ __STL_TYPENAME_ON_RETURN_TYPE basic_string<_CharT,_Traits,_Alloc>::size_type
#  define __iterator__  __STL_TYPENAME_ON_RETURN_TYPE basic_string<_CharT,_Traits,_Alloc>::iterator
# endif

__STL_BEGIN_NAMESPACE

#if defined (__STL_MEMBER_TEMPLATES) && ! defined (__STL_INLINE_MEMBER_TEMPLATES)
template <class _CharT, class _Traits, class _Alloc>  
template <class _ForwardIter>
basic_string<_CharT, _Traits, _Alloc>& 
basic_string<_CharT, _Traits, _Alloc>::append(_ForwardIter __first, _ForwardIter __last, 
					      forward_iterator_tag)
{
  __stl_debug_do(__check_range(__first, __last));
  if (__first != __last) {
    const size_type __old_size = size();
    difference_type __n = 0;
    distance(__first, __last, __n);
    if (__STATIC_CAST(size_type,__n) > max_size() || 
	__old_size > max_size() - __STATIC_CAST(size_type,__n))
      _M_throw_length_error();
    if (__old_size + __n > capacity()) {
      const size_type __len = __old_size +
	max(__old_size, __STATIC_CAST(size_type,__n)) + 1;
      pointer __new_start = _M_end_of_storage.allocate(__len);
      pointer __new_finish = __new_start;
      __STL_TRY {
	__new_finish = uninitialized_copy(_M_start, _M_finish, __new_start);
	__new_finish = uninitialized_copy(__first, __last, __new_finish);
	_M_construct_null(__new_finish);
      }
      __STL_UNWIND((destroy(__new_start,__new_finish),
		    _M_end_of_storage.deallocate(__new_start,__len)));
      destroy(_M_start, _M_finish + 1);
      _M_deallocate_block();
      _M_start = __new_start;
      _M_finish = __new_finish;
      _M_end_of_storage._M_data = __new_start + __len; 
    }
    else {
      _ForwardIter __f1 = __first;
      ++__f1;
      uninitialized_copy(__f1, __last, _M_finish + 1);
      __STL_TRY {
	_M_construct_null(_M_finish + __n);
      }
      __STL_UNWIND(destroy(_M_finish + 1, _M_finish + __n));
      _Traits::assign(*_M_finish, *__first);
      _M_finish += __n;
    }
  }
  return *this;  
}

template <class _CharT, class _Traits, class _Alloc>  template <class _ForwardIter>
void 
basic_string<_CharT, _Traits, _Alloc>::insert(iterator __position, 
					      _ForwardIter __first, _ForwardIter __last, 
					      forward_iterator_tag)  {
  __stl_debug_do(__check_range(__first,__last));
  if (__first != __last) {
    difference_type __n = 0;
    distance(__first, __last, __n);
    if (_M_end_of_storage._M_data - _M_finish >= __n + 1) {
      const difference_type __elems_after = _M_finish - _Make_ptr(__position);
      pointer __old_finish = _M_finish;
      if (__elems_after >= __n) {
	uninitialized_copy((_M_finish - __n) + 1, _M_finish + 1,
			   _M_finish + 1);
	_M_finish += __n;
	_Traits::move(_Make_ptr(__position) + __n,
		      _Make_ptr(__position), (__elems_after - __n) + 1);
	_M_copy(__first, __last, _Make_ptr(__position));
      }
      else {
	_ForwardIter __mid = __first;
	advance(__mid, __elems_after + 1);
	uninitialized_copy(__mid, __last, _M_finish + 1);
	_M_finish += __n - __elems_after;
	__STL_TRY {
	  uninitialized_copy(_Make_ptr(__position), __old_finish + 1, _M_finish);
	  _M_finish += __elems_after;
	}
	__STL_UNWIND((destroy(__old_finish + 1, _M_finish), 
		      _M_finish = __old_finish));
	_M_copy(__first, __mid, _Make_ptr(__position));
      }
    }
    else {
      const size_type __old_size = size();        
      const size_type __len
	= __old_size + max(__old_size, __STATIC_CAST(size_type,__n)) + 1;
      pointer __new_start = _M_end_of_storage.allocate(__len);
      pointer __new_finish = __new_start;
      __STL_TRY {
	__new_finish = uninitialized_copy(_M_start, _Make_ptr(__position), __new_start);
	__new_finish = uninitialized_copy(__first, __last, __new_finish);
	__new_finish
	  = uninitialized_copy(_Make_ptr(__position), _M_finish, __new_finish);
	_M_construct_null(__new_finish);
      }
      __STL_UNWIND((destroy(__new_start,__new_finish),
		    _M_end_of_storage.deallocate(__new_start,__len)));
      destroy(_M_start, _M_finish + 1);
      _M_deallocate_block();
      _M_start = __new_start;
      _M_finish = __new_finish;
      _M_end_of_storage._M_data = __new_start + __len; 
    }
  }
}

# endif /* __STL_INLINE_MEMBER_TEMPLATES */


// ------------------------------------------------------------
// Non-inline declarations.

# if (__STL_STATIC_TEMPLATE_DATA > 0)
template <class _CharT, class _Traits, class _Alloc> 
const __size_type__
basic_string<_CharT,_Traits,_Alloc>::npos = (size_t)-1;
# else /* __STL_STATIC_TEMPLATE_DATA */
template class basic_string<char,char_traits<char>,allocator<char> >;
const size_t string::npos __STL_WEAK = (size_t)-1;
#  ifdef __STL_HAS_WCHAR_T
template class basic_string<wchar_t,char_traits<wchar_t>,allocator<wchar_t> >;
const size_t wstring::npos __STL_WEAK = (size_t)-1;
#  endif
# endif /* __STL_STATIC_TEMPLATE_DATA */

// _String_base methods
template <class _Tp, class _Alloc> 
void _String_base<_Tp,_Alloc>::_M_throw_length_error() const {
  __STL_THROW(length_error(string("basic_string")));
}

template <class _Tp, class _Alloc> 
void _String_base<_Tp, _Alloc>::_M_throw_out_of_range() const {
  __STL_THROW(out_of_range(string("basic_string")));
}

// Change the string's capacity so that it is large enough to hold
//  at least __res_arg elements, plus the terminating _CharT().  Note that,
//  if __res_arg < capacity(), this member function may actually decrease
//  the string's capacity.
template <class _CharT, class _Traits, class _Alloc> 
void basic_string<_CharT,_Traits,_Alloc>::reserve(__size_type__ __res_arg) {
  if (__res_arg > max_size())
    _M_throw_length_error();

  size_type __n = max(__res_arg, size()) + 1;
  pointer __new_start = _M_end_of_storage.allocate(__n);
  pointer __new_finish = __new_start;

  __STL_TRY {
    __new_finish = uninitialized_copy(_M_start, _M_finish, __new_start);
    _M_construct_null(__new_finish);
  }
  __STL_UNWIND((destroy(__new_start, __new_finish), 
                _M_end_of_storage.deallocate(__new_start, __n)));

  destroy(_M_start, _M_finish + 1);
  _M_deallocate_block();
  _M_start = __new_start;
  _M_finish = __new_finish;
  _M_end_of_storage._M_data = __new_start + __n;
}

template <class _CharT, class _Traits, class _Alloc> 
basic_string<_CharT,_Traits,_Alloc>& 
basic_string<_CharT,_Traits,_Alloc>::append(__size_type__ __n, _CharT __c) {
  if (__n > max_size() || size() > max_size() - __n)
    _M_throw_length_error();
  if (size() + __n > capacity())
    reserve(size() + max(size(), __n));
  if (__n > 0) {
    uninitialized_fill_n(_M_finish + 1, __n - 1, __c);
    __STL_TRY {
      _M_construct_null(_M_finish + __n);
    }
    __STL_UNWIND(destroy(_M_finish + 1, _M_finish + __n));
    _Traits::assign(*_M_finish, __c);
    _M_finish += __n;
  }
  return *this;
}

#ifndef __STL_MEMBER_TEMPLATES

template <class _Tp, class _Traits, class _Alloc> 
basic_string<_Tp, _Traits, _Alloc>& 
basic_string<_Tp, _Traits, _Alloc>::append(const _Tp* __first,
                                           const _Tp* __last)
{
  if (__first != __last) {
    const size_type __old_size = size();
    ptrdiff_t __n = __last - __first;
    if ((size_type)__n > max_size() || __old_size > max_size() - __n)
      _M_throw_length_error();
    if (__old_size + __n > capacity()) {
      const size_type __len = __old_size + max(__old_size, (size_t) __n) + 1;
      pointer __new_start = _M_end_of_storage.allocate(__len);
      pointer __new_finish = __new_start;
      __STL_TRY {
        __new_finish = uninitialized_copy(_M_start, _M_finish, __new_start);
        __new_finish = uninitialized_copy(__first, __last, __new_finish);
        _M_construct_null(__new_finish);
      }
      __STL_UNWIND((destroy(__new_start,__new_finish),
                    _M_end_of_storage.deallocate(__new_start,__len)));
      destroy(_M_start, _M_finish + 1);
      _M_deallocate_block();
      _M_start = __new_start;
      _M_finish = __new_finish;
      _M_end_of_storage._M_data = __new_start + __len; 
    }
    else {
      const _Tp* __f1 = __first;
      ++__f1;
      uninitialized_copy(__f1, __last, _M_finish + 1);
      __STL_TRY {
        _M_construct_null(_M_finish + __n);
      }
      __STL_UNWIND(destroy(_M_finish + 1, _M_finish + __n));
      _Traits::assign(*_M_finish, *__first);
      _M_finish += __n;
    }
  }
  return *this;  
}

#endif /* __STL_MEMBER_TEMPLATES */

template <class _CharT, class _Traits, class _Alloc> 
basic_string<_CharT,_Traits,_Alloc>& 
basic_string<_CharT,_Traits,_Alloc>::assign(__size_type__ __n, _CharT __c) {
  if (__n <= size()) {
    _Traits::assign(_M_start, __n, __c);
    erase(begin() + __n, end());
  }
  else {
    _Traits::assign(_M_start, size(), __c);
    append(__n - size(), __c);
  }
  return *this;
}

template <class _CharT, class _Traits, class _Alloc> 
basic_string<_CharT,_Traits,_Alloc>& 
basic_string<_CharT,_Traits,_Alloc>::assign(const _CharT* __f, 
                                            const _CharT* __l)
{
  __stl_debug_do(__check_range(__f, __l));
  const ptrdiff_t __n = __l - __f;
  if (__STATIC_CAST(const size_type,__n) <= size()) {
    _Traits::copy(_M_start, __f, __n);
    erase(begin() + __n, end());
  }
  else {
    _Traits::copy(_M_start, __f, size());
    append(__f + size(), __l);
  }
  return *this;
}

template <class _CharT, class _Traits, class _Alloc>
_CharT* 
basic_string<_CharT,_Traits,_Alloc>
  ::_M_insert_aux(_CharT* __p,
                  _CharT __c)
{
  pointer __new_pos = __p;
  if (_M_finish + 1 < _M_end_of_storage._M_data) {
    _M_construct_null(_M_finish + 1);
    _Traits::move(__p + 1, __p, _M_finish - __p);
    _Traits::assign(*__p, __c);
    ++_M_finish;
  }
  else {
    const size_type __old_len = size();
    const size_type __len = __old_len +
                            max(__old_len, __STATIC_CAST(size_type,1)) + 1;
    pointer __new_start = _M_end_of_storage.allocate(__len);
    pointer __new_finish = __new_start;
    __STL_TRY {
      __new_pos = uninitialized_copy(_M_start, __p, __new_start);
      construct(__new_pos, __c);
      __new_finish = __new_pos + 1;
      __new_finish = uninitialized_copy(__p, _M_finish, __new_finish);
      _M_construct_null(__new_finish);

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲黄色录像片| 久久精品国产精品亚洲综合| 欧美日韩国产天堂| 国产精品资源站在线| 亚洲国产精品一区二区尤物区| 欧美大度的电影原声| 91丨porny丨户外露出| 久99久精品视频免费观看| 亚洲激情网站免费观看| 久久久综合九色合综国产精品| 欧美私模裸体表演在线观看| 成人丝袜视频网| 久久精品99国产精品| 亚洲一区二区三区四区在线免费观看| 欧美成人在线直播| 欧美日韩国产天堂| 欧美综合亚洲图片综合区| 国产+成+人+亚洲欧洲自线| 欧美aⅴ一区二区三区视频| 亚洲欧美一区二区三区国产精品| 久久久无码精品亚洲日韩按摩| 欧美理论在线播放| 91丨porny丨中文| 成人性视频免费网站| 国产一区亚洲一区| 久久精品国产一区二区三区免费看| 亚洲午夜电影在线观看| 亚洲精品乱码久久久久| 中文字幕一区二区不卡| 国产女人水真多18毛片18精品视频 | 午夜视频在线观看一区| 亚洲美女淫视频| 亚洲精品一二三四区| 亚洲色图视频网站| 亚洲精品视频观看| 亚洲国产日韩综合久久精品| 亚洲另类在线视频| 最新久久zyz资源站| 亚洲欧美中日韩| 国产精品理论在线观看| 欧美国产一区二区在线观看| 国产女人aaa级久久久级 | 久久久亚洲国产美女国产盗摄| 欧美一区二区三区不卡| 欧美精品乱码久久久久久按摩| 在线观看91精品国产入口| 色综合色狠狠综合色| 92精品国产成人观看免费| 97久久精品人人做人人爽50路| 成人av资源下载| 91在线看国产| 欧美日韩一区二区三区不卡 | 色国产精品一区在线观看| 99免费精品视频| 色综合久久久久久久| 色综合中文字幕| 欧美日韩国产系列| 欧美电影精品一区二区| 久久久www成人免费毛片麻豆 | 久久九九久久九九| 国产精品入口麻豆九色| 亚洲免费高清视频在线| 亚洲小少妇裸体bbw| 秋霞午夜鲁丝一区二区老狼| 久久99久久精品欧美| 国产成人精品影视| 色综合久久精品| 日韩一区二区三| 中日韩免费视频中文字幕| 亚洲最新在线观看| 久久激情五月婷婷| av在线免费不卡| 欧美一级欧美一级在线播放| 久久精品一区四区| 夜夜夜精品看看| 久久99精品久久久久久动态图| 国产福利91精品| 欧洲av一区二区嗯嗯嗯啊| 日韩欧美国产综合一区| 中文字幕一区二区三区蜜月| 亚洲成人免费在线| 国产成人av自拍| 欧美三级中文字| 久久亚洲一级片| 亚洲午夜免费视频| 国产精品亚洲专一区二区三区| 色就色 综合激情| 久久久亚洲精华液精华液精华液| 亚洲综合小说图片| 丰满岳乱妇一区二区三区| 欧美少妇xxx| 国产精品全国免费观看高清| 亚洲h在线观看| 成人一区二区三区视频| 日韩一区二区三区在线| 亚洲欧洲99久久| 经典三级一区二区| 精品视频免费在线| 国产精品视频麻豆| 开心九九激情九九欧美日韩精美视频电影 | 国产精品美女久久久久av爽李琼| 亚洲丰满少妇videoshd| 成人三级伦理片| 精品国产成人在线影院 | 理论片日本一区| 日本道色综合久久| 国产免费成人在线视频| 久久66热re国产| 欧美高清www午色夜在线视频| 国产精品麻豆一区二区| 久草这里只有精品视频| 欧美一区二区三区在线| 亚洲欧洲中文日韩久久av乱码| 国产成人精品午夜视频免费 | 一区二区三区小说| 国产99久久久久| 久久综合狠狠综合| 久久99久久精品欧美| 在线不卡中文字幕播放| 夜夜揉揉日日人人青青一国产精品| 成人黄色综合网站| 国产亚洲视频系列| 国产精品一线二线三线| 欧美电影免费观看高清完整版在线| 亚洲成av人片一区二区梦乃| 色综合久久天天| 自拍av一区二区三区| 成人av电影在线| 国产精品久久久久久亚洲毛片| 国产精品1区2区3区| 精品电影一区二区| 国产一区二区三区国产| 久久精品一区二区三区av| 国精产品一区一区三区mba桃花| 精品精品国产高清a毛片牛牛| 久久精品国产澳门| 欧美mv日韩mv亚洲| 国产专区欧美精品| 26uuu亚洲综合色| 国产一区二区三区免费在线观看 | 日韩欧美的一区| 免费欧美日韩国产三级电影| 欧美一级爆毛片| 久久精品国产免费看久久精品| 欧美一区二区三区不卡| 久久99精品久久只有精品| 精品国产自在久精品国产| 国内精品国产成人国产三级粉色| 久久综合色鬼综合色| 国产成人免费视频网站高清观看视频| 国产日韩精品视频一区| 成人午夜视频网站| 一区二区三区在线免费视频| 欧美日韩精品专区| 久久精品久久99精品久久| 国产亚洲欧美一区在线观看| 成人av资源下载| 丝袜美腿亚洲一区二区图片| 日韩午夜激情免费电影| 国产黄色91视频| 一区二区中文字幕在线| 欧美色精品天天在线观看视频| 免费在线一区观看| 国产精品三级电影| 欧美视频日韩视频在线观看| 免费视频一区二区| 中文字幕永久在线不卡| 欧美日韩亚洲综合一区二区三区 | 91丨九色丨尤物| 丝袜国产日韩另类美女| 国产色综合一区| 日本精品裸体写真集在线观看| 蜜桃传媒麻豆第一区在线观看| 中文欧美字幕免费| 欧美老女人第四色| 国产成人欧美日韩在线电影| 亚洲最大成人网4388xx| 精品成人一区二区三区四区| 91视频com| 久久国产日韩欧美精品| 自拍偷拍国产精品| 欧美tickling挠脚心丨vk| 日本高清视频一区二区| 精品在线观看免费| 亚洲综合男人的天堂| 欧美精品一区二区精品网| 一本色道综合亚洲| 国产一区久久久| 天堂va蜜桃一区二区三区 | 国产精品欧美一区二区三区| 欧美日韩激情一区| 成人精品电影在线观看| 日韩av在线发布| 亚洲日本在线看| 国产欧美一区二区精品忘忧草| 欧美日韩日本视频| 97精品电影院| 国产精品456| 久久精品国产免费| 婷婷久久综合九色综合伊人色|