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

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

?? stl_deque.c

?? 粗慥集成算法集合 ,并有詳細的文檔資料和測試數據處
?? C
?? 第 1 頁 / 共 3 頁
字號:
}

template <class _Tp, class _Alloc, size_t __bufsiz>
void deque<_Tp,_Alloc,__bufsiz>::clear()
{
  __stl_debug_do(_Invalidate_all());
  for (_Map_pointer __node = _M_start._M_node + 1;
       __node < _M_finish._M_node;
       ++__node) {
    destroy(*__node, *__node + __buf_traits::_buf_size);
    _M_map_size.deallocate(*__node, __buf_traits::_buf_size);
  }

  if (_M_start._M_node != _M_finish._M_node) {
    destroy(_M_start._M_cur, _M_start._M_last);
    destroy(_M_finish._M_first, _M_finish._M_cur);
    _M_map_size.deallocate(_M_finish._M_first, __buf_traits::_buf_size);
  }
  else
    destroy(_M_start._M_cur, _M_finish._M_cur);

  _M_finish = _M_start;
  __stl_debug_do(_M_orphan_finish());
}

// Precondition: _M_start and _M_finish have already been initialized,
// but none of the deque's elements have yet been constructed.
template <class _Tp, class _Alloc, size_t __bufsiz>
void 
deque<_Tp,_Alloc,__bufsiz>::_M_fill_initialize(const value_type& __value) {
  _Map_pointer __cur;
  __stl_debug_do(_M_iter_list._Safe_init(&_M_start));
  __stl_debug_do(_Init_bounds());
  __STL_TRY {
    for (__cur = _M_start._M_node; __cur < _M_finish._M_node; ++__cur)
      uninitialized_fill(*__cur, *__cur + __buf_traits::_buf_size, __value);
    uninitialized_fill(_M_finish._M_first, _M_finish._M_cur, __value);
  }
# ifdef __STL_DEBUG
  __STL_UNWIND(destroy(_M_start, iterator(&_M_iter_list,*__cur, __cur)));
# else
  __STL_UNWIND(destroy(_M_start, iterator(*__cur, __cur)));
# endif
}


// Called only if _M_finish._M_cur == _M_finish._M_last - 1.
template <class _Tp, class _Alloc, size_t __bufsiz>
void
deque<_Tp,_Alloc,__bufsiz>::_M_push_back_aux(const value_type& __t)
{
  value_type __t_copy = __t;
  _M_reserve_map_at_back();
  *(_M_finish._M_node + 1) = _M_map_size.allocate(__buf_traits::_buf_size);
  __STL_TRY {
    construct(_M_finish._M_cur, __t_copy);
    _M_finish._M_set_node(_M_finish._M_node + 1);
    _M_finish._M_cur = _M_finish._M_first;
  }
  __STL_UNWIND(_M_map_size.deallocate(*(_M_finish._M_node + 1), 
				      __buf_traits::_buf_size));
}

// Called only if _M_finish._M_cur == _M_finish._M_last - 1.
template <class _Tp, class _Alloc, size_t __bufsiz>
void
deque<_Tp,_Alloc,__bufsiz>::_M_push_back_aux()
{
  _M_reserve_map_at_back();
  *(_M_finish._M_node + 1) = _M_map_size.allocate(__buf_traits::_buf_size);
  __STL_TRY {
    construct(_M_finish._M_cur);
    _M_finish._M_set_node(_M_finish._M_node + 1);
    _M_finish._M_cur = _M_finish._M_first;
  }
  __STL_UNWIND(_M_map_size.deallocate(*(_M_finish._M_node + 1), 
				      __buf_traits::_buf_size));
}

// Called only if _M_start._M_cur == _M_start._M_first.
template <class _Tp, class _Alloc, size_t __bufsiz>
void 
deque<_Tp,_Alloc,__bufsiz>::_M_push_front_aux(const value_type& __t)
{
  value_type __t_copy = __t;
  _M_reserve_map_at_front();
  *(_M_start._M_node - 1) = _M_map_size.allocate(__buf_traits::_buf_size);
  __STL_TRY {
    _M_start._M_set_node(_M_start._M_node - 1);
    _M_start._M_cur = _M_start._M_last - 1;
    construct(_M_start._M_cur, __t_copy);
  }
  __STL_UNWIND((++_M_start, 
		_M_map_size.deallocate(*(_M_start._M_node - 1), __buf_traits::_buf_size)));
} 

// Called only if _M_start._M_cur == _M_start._M_first.
template <class _Tp, class _Alloc, size_t __bufsiz>
void 
deque<_Tp,_Alloc,__bufsiz>::_M_push_front_aux()
{
  _M_reserve_map_at_front();
  *(_M_start._M_node - 1) = _M_map_size.allocate(__buf_traits::_buf_size);
  __STL_TRY {
    _M_start._M_set_node(_M_start._M_node - 1);
    _M_start._M_cur = _M_start._M_last - 1;
    construct(_M_start._M_cur);
  }
  __STL_UNWIND((++_M_start, _M_map_size.deallocate(*(_M_start._M_node - 1), 
						   __buf_traits::_buf_size )));
} 

// Called only if _M_finish._M_cur == _M_finish._M_first.
template <class _Tp, class _Alloc, size_t __bufsiz>
void 
deque<_Tp,_Alloc,__bufsiz>::_M_pop_back_aux()
{
  _M_map_size.deallocate(_M_finish._M_first, __buf_traits::_buf_size);
  _M_finish._M_set_node(_M_finish._M_node - 1);
  _M_finish._M_cur = _M_finish._M_last - 1;
  destroy(_M_finish._M_cur);
}

// Called only if _M_start._M_cur == _M_start._M_last - 1.  Note that 
// if the deque has at least one element (a precondition for this member 
// function), and if _M_start._M_cur == _M_start._M_last, then the deque 
// must have at least two nodes.
template <class _Tp, class _Alloc, size_t __bufsiz>
void 
deque<_Tp,_Alloc,__bufsiz>::_M_pop_front_aux()
{
  destroy(_M_start._M_cur);
  _M_map_size.deallocate(_M_start._M_first, __buf_traits::_buf_size);
  _M_start._M_set_node(_M_start._M_node + 1);
  _M_start._M_cur = _M_start._M_first;
}      

template <class _Tp, class _Alloc, size_t __bufsiz>
__iterator__
deque<_Tp,_Alloc,__bufsiz>::_M_insert_aux(__iterator__ __pos,
                                           const value_type& __x) {
  difference_type __index = __pos - _M_start;
  value_type __x_copy = __x;
  if (__index < difference_type(size() / 2)) {
    push_front(front());
    iterator __front1 = _M_start;
    ++__front1;
    iterator __front2 = __front1;
    ++__front2;
    __pos = _M_start + __index;
    iterator __pos1 = __pos;
    ++__pos1;
    copy(__front2, __pos1, __front1);
  }
  else {
    push_back(back());
    iterator __back1 = _M_finish;
    --__back1;
    iterator __back2 = __back1;
    --__back2;
    __pos = _M_start + __index;
    copy_backward(__pos, __back2, __back1);
  }
  *__pos = __x_copy;
  return __pos;
}

template <class _Tp, class _Alloc, size_t __bufsiz>
__iterator__
deque<_Tp,_Alloc,__bufsiz>::_M_insert_aux(__iterator__ __pos)
{
  difference_type __index = __pos - _M_start;
  if (__index < difference_type(size() / 2)) {
    push_front(front());
    iterator __front1 = _M_start;
    ++__front1;
    iterator __front2 = __front1;
    ++__front2;
    __pos = _M_start + __index;
    iterator __pos1 = __pos;
    ++__pos1;
    copy(__front2, __pos1, __front1);
  }
  else {
    push_back(back());
    iterator __back1 = _M_finish;
    --__back1;
    iterator __back2 = __back1;
    --__back2;
    __pos = _M_start + __index;
    copy_backward(__pos, __back2, __back1);
  }
  *__pos = value_type();
  return __pos;
}

template <class _Tp, class _Alloc, size_t __bufsiz>
void
deque<_Tp,_Alloc,__bufsiz>::_M_insert_aux(iterator __pos,
                                           size_type __n,
                                           const value_type& __x)
{
  const difference_type __elems_before = __pos - _M_start;
  size_type __length = size();
  value_type __x_copy = __x;
  if (__elems_before < difference_type(__length / 2)) {
    iterator __new_start = _M_reserve_elements_at_front(__n);
    iterator __old_start = _M_start;
    __pos = _M_start + __elems_before;
    __STL_TRY {
      if (__elems_before >= difference_type(__n)) {
        iterator __start_n = _M_start + difference_type(__n);
        uninitialized_copy(_M_start, __start_n, __new_start);
        _M_start = __new_start;
	__stl_debug_do(_M_orphan_start());
        copy(__start_n, __pos, __old_start);
        fill(__pos - difference_type(__n), __pos, __x_copy);
      }
      else {
        __uninitialized_copy_fill(_M_start, __pos, __new_start, 
	                          _M_start, __x_copy);
        _M_start = __new_start;
	__stl_debug_do(_M_orphan_start());
        fill(__old_start, __pos, __x_copy);
      }
    }
    __STL_UNWIND(_M_destroy_nodes(__new_start._M_node, _M_start._M_node));
  }
  else {
    iterator __new_finish = _M_reserve_elements_at_back(__n);
    iterator __old_finish = _M_finish;
    const difference_type __elems_after = 
      difference_type(__length) - __elems_before;
    __pos = _M_finish - __elems_after;
    __STL_TRY {
      if (__elems_after > difference_type(__n)) {
        iterator __finish_n = _M_finish - difference_type(__n);
        uninitialized_copy(__finish_n, _M_finish, _M_finish);
        _M_finish = __new_finish;
	__stl_debug_do(_M_orphan_finish());
        copy_backward(__pos, __finish_n, __old_finish);
        fill(__pos, __pos + difference_type(__n), __x_copy);
      }
      else {
        __uninitialized_fill_copy(_M_finish, __pos + difference_type(__n),
                                  __x_copy, __pos, _M_finish);
        _M_finish = __new_finish;
	__stl_debug_do(_M_orphan_finish());	
        fill(__pos, __old_finish, __x_copy);
      }
    }
    __STL_UNWIND(_M_destroy_nodes(_M_finish._M_node + 1, __new_finish._M_node + 1));
  }
  __stl_debug_do(_Invalidate_all());        
}

#ifndef __STL_MEMBER_TEMPLATES 
template <class _Tp, class _Alloc, size_t __bufsiz>
void 
deque<_Tp,_Alloc,__bufsiz>::_M_insert_aux(iterator __pos,
                                           const value_type* __first,
                                           const value_type* __last,
                                           size_type __n)
{

  const difference_type __elemsbefore = __pos - _M_start;
  size_type __length = size();
  if (__elemsbefore < difference_type(__length / 2)) {
    iterator __new_start = _M_reserve_elements_at_front(__n);
    iterator __old_start = _M_start;
    __pos = _M_start + __elemsbefore;
    __STL_TRY {
      if (__elemsbefore >= difference_type(__n)) {
        iterator __start_n = _M_start + difference_type(__n);
        uninitialized_copy(_M_start, __start_n, __new_start);
        _M_start = __new_start;
	__stl_debug_do(_M_orphan_start());
        copy(__start_n, __pos, __old_start);
        copy(__first, __last, __pos - difference_type(__n));
      }
      else {
        const value_type* __mid = 
	  __first + (difference_type(__n) - __elemsbefore);
        __uninitialized_copy_copy(_M_start, __pos, __first, __mid,
                                  __new_start);
        _M_start = __new_start;
	__stl_debug_do(_M_orphan_start());
        copy(__mid, __last, __old_start);
      }
    }
    __STL_UNWIND(_M_destroy_nodes(__new_start._M_node, _M_start._M_node));
  }
  else {
    iterator __new_finish = _M_reserve_elements_at_back(__n);
    iterator __old_finish = _M_finish;
    const difference_type __elemsafter = 
      difference_type(__length) - __elemsbefore;
    __pos = _M_finish - __elemsafter;
    __STL_TRY {
      if (__elemsafter > difference_type(__n)) {
        iterator __finish_n = _M_finish - difference_type(__n);
        uninitialized_copy(__finish_n, _M_finish, _M_finish);
        _M_finish = __new_finish;
	__stl_debug_do(_M_orphan_finish());
        copy_backward(__pos, __finish_n, __old_finish);
        copy(__first, __last, __pos);
      }
      else {
        const value_type* __mid = __first + __elemsafter;
        __uninitialized_copy_copy(__mid, __last, __pos, _M_finish, _M_finish);
        _M_finish = __new_finish;
	__stl_debug_do(_M_orphan_finish());
        copy(__first, __mid, __pos);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩亚洲欧美在线观看| 一个色妞综合视频在线观看| 欧美国产丝袜视频| 亚洲成人1区2区| 成人99免费视频| 精品99一区二区| 亚洲电影在线播放| 成人激情小说网站| 日韩精品一区二区在线观看| 亚洲精品乱码久久久久久日本蜜臀| 国内精品第一页| 日韩一区二区高清| 亚洲电影激情视频网站| 99久精品国产| 国产精品无人区| 精品一区二区影视| 日韩欧美国产一二三区| 一区二区三区精品视频| 成人免费黄色大片| 2021久久国产精品不只是精品| 一区二区三区国产精华| 99久久伊人久久99| 国产欧美一区二区三区沐欲| 日本中文字幕一区二区视频| 在线亚洲+欧美+日本专区| 中日韩免费视频中文字幕| 国精品**一区二区三区在线蜜桃| 777亚洲妇女| 天天综合天天做天天综合| 欧美性大战久久| 一级精品视频在线观看宜春院 | 在线观看日韩高清av| 中文字幕精品一区 | 日日摸夜夜添夜夜添国产精品| 91看片淫黄大片一级在线观看| 国产精品久99| 色综合网站在线| 亚洲综合视频在线| 欧美日韩国产高清一区二区三区| 一区二区三区四区不卡视频 | 自拍偷拍国产精品| 色老综合老女人久久久| 中文字幕一区二区三区四区| 国产在线播放一区三区四| www欧美成人18+| 国产精品原创巨作av| 欧美激情资源网| 91在线观看免费视频| 亚洲影视在线播放| 日韩一区二区三区在线视频| 韩国毛片一区二区三区| 国产精品天美传媒| 在线亚洲欧美专区二区| 日韩精品成人一区二区在线| 精品国产a毛片| 99麻豆久久久国产精品免费 | 欧美日韩在线免费视频| 男男视频亚洲欧美| 国产精品久久看| 欧美性做爰猛烈叫床潮| 青青草成人在线观看| 久久综合九色欧美综合狠狠| 不卡av在线网| 亚洲综合另类小说| 欧美久久婷婷综合色| 国产一区二区三区最好精华液| 日本一区二区三区四区 | 亚洲一二三四区| 日韩免费看的电影| 高清不卡一区二区在线| 一区二区日韩av| 欧美mv日韩mv| 一本一道综合狠狠老| 乱一区二区av| 亚洲综合色自拍一区| 精品成人a区在线观看| 色婷婷综合五月| 激情综合网激情| 亚洲激情av在线| 久久精品人人做| 欧美日韩精品欧美日韩精品一 | 日韩精品一级二级| 国产精品传媒视频| 欧美变态口味重另类| 91热门视频在线观看| 毛片av中文字幕一区二区| 亚洲私人影院在线观看| 欧美xingq一区二区| 在线免费观看一区| 成人午夜免费视频| 久久不见久久见中文字幕免费| 136国产福利精品导航| 日韩手机在线导航| 欧美色老头old∨ideo| 国产成人精品免费看| 久久国内精品视频| 视频一区二区三区在线| 亚洲毛片av在线| 国产精品三级电影| 久久综合av免费| 日韩一级黄色片| 欧美日韩国产a| 91福利在线观看| 国产高清在线精品| 精品综合免费视频观看| 日韩国产欧美在线播放| 一区二区三区电影在线播| 中文字幕一区二| 中文字幕电影一区| 久久精品一区二区三区不卡牛牛| 日韩欧美视频在线| 日韩女优毛片在线| 日韩午夜在线影院| 日韩美女在线视频| 日韩欧美一区二区在线视频| 欧美伦理电影网| 欧美嫩在线观看| 69av一区二区三区| 欧美一级日韩免费不卡| 欧美一级在线视频| 日韩精品在线看片z| 91精品国产乱码久久蜜臀| 欧美日韩一级二级| 91精品国产综合久久香蕉麻豆| 欧美日韩精品欧美日韩精品一综合| 欧美性xxxxxxxx| 欧美一级一区二区| 欧美精品一区二区精品网| 精品毛片乱码1区2区3区| 久久亚洲免费视频| 亚洲欧洲成人av每日更新| 亚洲精品视频自拍| 奇米四色…亚洲| 国产乱子伦视频一区二区三区 | 精品制服美女丁香| 国产suv精品一区二区6| 99在线精品一区二区三区| 一本色道久久综合精品竹菊| 欧美主播一区二区三区| 欧美久久一二三四区| 久久综合狠狠综合| 亚洲欧美怡红院| 天天综合色天天综合| 国产精品一区二区三区四区 | 一区二区三区久久| 日韩电影在线一区| 国产99精品国产| 欧美日韩在线播| 欧美成人艳星乳罩| 日韩美女久久久| 免费欧美高清视频| 91亚洲精品一区二区乱码| 欧美性大战久久久| 国产欧美日韩另类一区| 亚洲一区在线观看免费观看电影高清| 热久久免费视频| 99久久久国产精品| 欧美一区二区三区色| 日本一区二区三区高清不卡 | 欧美无乱码久久久免费午夜一区 | 91黄色免费网站| 欧美mv和日韩mv的网站| 亚洲视频小说图片| 久久99久久99精品免视看婷婷| 99视频热这里只有精品免费| 欧美一区二区在线看| 中文字幕一区在线| 九色综合狠狠综合久久| 欧美在线观看禁18| 国产精品卡一卡二卡三| 美女爽到高潮91| 欧美午夜一区二区三区免费大片| 久久亚洲影视婷婷| 日韩国产欧美在线观看| 在线观看欧美日本| 国产精品乱码一区二区三区软件 | 午夜一区二区三区视频| 成人免费毛片嘿嘿连载视频| 日韩欧美一二三四区| 天天色图综合网| 在线观看国产一区二区| 国产精品激情偷乱一区二区∴| 久久精品国产99久久6| 欧美日韩另类一区| 一区二区三区日韩欧美精品| 成人av在线影院| 国产精品视频看| 国产在线国偷精品产拍免费yy| 91精品国模一区二区三区| 图片区日韩欧美亚洲| 欧美亚洲国产一区二区三区va| 国产日韩欧美综合在线| 韩国理伦片一区二区三区在线播放| 91精品婷婷国产综合久久竹菊| 一级女性全黄久久生活片免费| 色婷婷国产精品久久包臀| 日韩毛片精品高清免费| 91在线观看下载| 一区二区在线观看视频在线观看| 99视频国产精品|