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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? stl_string.c

?? 粗慥集成算法集合 ,并有詳細的文檔資料和測試數據處
?? C
?? 第 1 頁 / 共 3 頁
字號:
/*
 *
 *
 * 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);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
天堂蜜桃一区二区三区| 天天色 色综合| 久久免费午夜影院| 日韩欧美激情在线| 91精品国产高清一区二区三区蜜臀| 91美女在线观看| 91蜜桃网址入口| 欧美伊人久久久久久久久影院| 在线一区二区三区| 在线观看免费一区| 欧美日韩国产另类不卡| 欧美一区二区精品久久911| 欧美一级理论性理论a| 欧美高清视频一二三区| 91麻豆精品国产91久久久使用方法 | 麻豆freexxxx性91精品| 久久精品国产免费看久久精品| 精品一区二区免费视频| 国产精品18久久久久久久久久久久 | 国产成人自拍高清视频在线免费播放 | 亚洲日本护士毛茸茸| 玉足女爽爽91| 玖玖九九国产精品| 成人app软件下载大全免费| 色爱区综合激月婷婷| 欧美一区二区三区啪啪| 国产欧美一区二区精品性| 亚洲激情一二三区| 蜜臀精品一区二区三区在线观看 | 亚洲国产成人高清精品| 九色|91porny| jvid福利写真一区二区三区| 欧美日韩高清一区二区不卡| 精品国产91乱码一区二区三区 | 成+人+亚洲+综合天堂| 在线观看av一区二区| 日韩欧美国产综合在线一区二区三区| 欧美激情一区不卡| 亚洲国产aⅴ天堂久久| 国产一区二区三区精品欧美日韩一区二区三区 | 国产精品一区久久久久| 91久久精品午夜一区二区| 精品国产免费人成在线观看| 一区二区三区中文字幕| 国产一区二区在线电影| 欧美日韩二区三区| 亚洲美女精品一区| 国产激情精品久久久第一区二区| 欧美精品久久一区| 亚洲免费伊人电影| 成人av在线一区二区三区| 日韩欧美中文字幕公布| 一区二区在线观看免费视频播放| 久久精品国产久精国产爱| 欧美日韩亚洲综合在线| 亚洲人成网站色在线观看| 国产伦精品一区二区三区免费 | 精品系列免费在线观看| 欧美日韩高清影院| 一区二区三区四区乱视频| 国产一区二区不卡在线| 欧美videossexotv100| 日韩电影一区二区三区四区| 日本韩国欧美三级| 最新国产の精品合集bt伙计| 成人视屏免费看| 中文成人综合网| 国产超碰在线一区| 国产亚洲自拍一区| 国产一区二区三区四区五区美女| 日韩欧美国产综合| 经典三级视频一区| 国产色产综合色产在线视频| 国产一区二区三区美女| 国产视频一区在线播放| 成人黄色软件下载| 国产精品视频免费看| 波多野结衣在线aⅴ中文字幕不卡 波多野结衣在线一区 | 成人av网站在线观看| 国产精品乱码妇女bbbb| 国产成人欧美日韩在线电影| 国产欧美一区二区精品忘忧草| 国产精品自拍在线| 中文字幕一区三区| 色婷婷久久久亚洲一区二区三区| 一区二区三区在线免费观看| 精品视频123区在线观看| 亚洲成人av一区二区| 67194成人在线观看| 久久成人精品无人区| 久久久91精品国产一区二区精品| 成人精品视频.| 亚洲伊人伊色伊影伊综合网| 欧美丰满美乳xxx高潮www| 精品一区二区三区蜜桃| 国产精品白丝在线| 欧美精品 日韩| 丁香婷婷综合五月| 亚洲一区二区中文在线| 欧美精品一区二区久久婷婷| bt7086福利一区国产| 午夜视频在线观看一区二区| 精品国产sm最大网站| 97se亚洲国产综合自在线观| 天天综合网 天天综合色| 久久久亚洲高清| 91官网在线免费观看| 韩国一区二区三区| 亚洲激情图片小说视频| 精品免费国产一区二区三区四区| 国产不卡免费视频| 视频一区二区欧美| 国产精品美女久久福利网站| 欧美精品粉嫩高潮一区二区| 成人av先锋影音| 免费成人在线播放| 亚洲美女在线一区| 国产亚洲成av人在线观看导航| 欧美亚洲国产bt| 国产成人免费视频| 秋霞午夜鲁丝一区二区老狼| 亚洲欧洲成人精品av97| 精品久久久久久久久久久久久久久 | 亚洲高清不卡在线观看| 国产人妖乱国产精品人妖| 欧美日韩国产免费| 99久久婷婷国产精品综合| 国产中文字幕精品| 日韩高清国产一区在线| 一区二区免费视频| 国产精品理伦片| 久久无码av三级| 日韩欧美一级在线播放| 欧美三级电影精品| 91毛片在线观看| 成人91在线观看| 成人午夜短视频| 国产麻豆精品一区二区| 另类小说欧美激情| 日韩高清不卡在线| 亚洲一二三四在线| 亚洲欧洲综合另类| 亚洲欧洲中文日韩久久av乱码| 中文字幕高清不卡| 国产日韩精品一区二区浪潮av| 精品福利二区三区| 日韩一区二区三区四区| 日韩一区二区三免费高清| 欧美蜜桃一区二区三区| 欧美亚洲图片小说| 欧美男同性恋视频网站| 欧美高清性hdvideosex| 欧美高清视频在线高清观看mv色露露十八| 色成人在线视频| 欧美日韩视频在线第一区 | 日本vs亚洲vs韩国一区三区二区 | 1区2区3区欧美| 亚洲视频狠狠干| 亚洲激情五月婷婷| 亚洲永久免费av| 午夜国产不卡在线观看视频| 日韩中文字幕麻豆| 麻豆传媒一区二区三区| 久久av资源网| 国产成人av一区二区三区在线| 国产精品亚洲专一区二区三区| 国产精品一区2区| av电影天堂一区二区在线| 91欧美一区二区| 欧美三级视频在线| 欧美一区二区视频在线观看| 精品乱人伦小说| 中文字幕第一区二区| 亚洲精品亚洲人成人网| 日韩成人免费电影| 国产成人av电影| 在线免费观看成人短视频| 91精品国产综合久久久久久久| 精品捆绑美女sm三区| 国产精品色哟哟网站| 亚洲综合免费观看高清完整版| 青青草97国产精品免费观看 | caoporn国产精品| 欧美午夜片在线看| 久久欧美中文字幕| 亚洲欧美日韩国产一区二区三区| 午夜国产不卡在线观看视频| 国产精品一区在线观看乱码| 欧美亚洲自拍偷拍| 国产欧美日韩综合| 日本成人在线电影网| 91在线一区二区三区| 欧美高清dvd| 自拍av一区二区三区| 久久国产精品99久久久久久老狼 | 国产成都精品91一区二区三| 欧美精品国产精品| 亚洲男同1069视频| 国产麻豆欧美日韩一区| 91精品国产丝袜白色高跟鞋|