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

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

?? stl_deque.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_DEQUE_C
#define __STL_DEQUE_C

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

# undef deque
# if defined ( __STL_NO_DEFAULT_NON_TYPE_PARAM )
#  define deque __deque
# else
#  define deque __WORKAROUND_RENAME(deque)
# endif

__STL_BEGIN_NAMESPACE

# ifdef __STL_DEBUG
// this hack is horrible, but, given no Alloc parameter
// for _Deque_iterator, we are not able to restore full deque structure anyways

template <class _Tp>
struct _Deq_iter_guts : public __owned_link {
  _Tp* _M_cur;
  _Tp* _M_first;
  _Tp* _M_last;
  _Tp** _M_node; 
  bool _M_unsafe;
};

// We do not send __ptr as _Tp*, as only void* is guaranteed to hold any pointer
template <class _Tp>
bool __Deq_dereferenceable(const void* __ptr, _Tp*) {
  typedef _Deq_iter_guts<_Tp> _Guts;
  const _Guts * __guts = (const _Guts*)(void*)__ptr;
  __stl_verbose_return(__guts->_Valid(), _StlMsg_INVALID_ITERATOR);
  
  if (__guts->_M_unsafe) return true;
  
  const _Guts* __start = (const _Guts*)(__guts->_Owner()->_Owner());
  const _Guts* __finish = __start+1;
  
  __stl_verbose_return(
		       ((__guts->_M_node == __finish->_M_node) ? /* *__guts < *__finish */
			(__guts->_M_cur < __finish->_M_cur) : (__guts->_M_node < __finish->_M_node)) &&
		       
		       !((__guts->_M_node == __start->_M_node) ?     /* ! (*__guts < *__start) */
			 (__guts->_M_cur < __start->_M_cur) : (__guts->_M_node < __start->_M_node)),
		       _StlMsg_NOT_DEREFERENCEABLE); 
  return true;  
}

template <class _Tp>
bool __Deq_nonsingular(const void* __ptr, _Tp*) {
  typedef _Deq_iter_guts<_Tp> _Guts;
  const _Guts * __guts = (const _Guts*)(void*)__ptr;
  __stl_verbose_return(__guts->_Valid(), _StlMsg_INVALID_ITERATOR);
  
  if (__guts->_M_unsafe) return true;
  
  const _Guts* __start = (const _Guts*)(__guts->_Owner()->_Owner());
  const _Guts* __finish = __start+1;
  
  __stl_verbose_return(
		       !(((__guts->_M_node == __finish->_M_node) ? /* *__guts > *__finish */
			(__guts->_M_cur > __finish->_M_cur) : (__guts->_M_node > __finish->_M_node)) ||
		       
		       ((__guts->_M_node == __start->_M_node) ?     /* (*__guts < *__start) */
			 (__guts->_M_cur < __start->_M_cur) : (__guts->_M_node < __start->_M_node))),
		       _StlMsg_SINGULAR_ITERATOR); 
  return true;  
}

#  endif

// Non-inline member functions from _Deque_base.

template <class _Tp, class _Alloc, size_t __bufsiz>
_Deque_base<_Tp,_Alloc,__bufsiz>::~_Deque_base() {
  if (_M_map._M_data) {
    _M_destroy_nodes(_M_start._M_node, _M_finish._M_node + 1);
    _M_map.deallocate(_M_map._M_data, _M_map_size._M_data);
  }
  // should be done here instead of ~deque to ensure 
  // no detach is ever possible
  __stl_debug_do(_M_start._Invalidate());
  __stl_debug_do(_M_finish._Invalidate());
}

template <class _Tp, class _Alloc, size_t __bufsiz>
void
_Deque_base<_Tp,_Alloc,__bufsiz>::_M_initialize_map(size_t __num_elements)
{
  size_t __num_nodes = 
    __num_elements / __deque_buf_size(__bufsiz, sizeof(_Tp)) + 1;

  _M_map_size._M_data = max((size_t) _S_initial_map_size, __num_nodes + 2);
  _M_map._M_data = _M_map.allocate(_M_map_size._M_data);

  _Tp** __nstart = _M_map._M_data + (_M_map_size._M_data - __num_nodes) / 2;
  _Tp** __nfinish = __nstart + __num_nodes;
    
  __STL_TRY {
    _M_create_nodes(__nstart, __nfinish);
  }
  __STL_UNWIND((_M_map.deallocate(_M_map._M_data, _M_map_size._M_data), 
                _M_map._M_data = 0, _M_map_size._M_data = 0));
  _M_start._M_set_node(__nstart);
  _M_finish._M_set_node(__nfinish - 1);
  _M_start._M_cur = _M_start._M_first;
  _M_finish._M_cur = _M_finish._M_first +
               __num_elements % __deque_buf_size(__bufsiz, sizeof(_Tp));
}

template <class _Tp, class _Alloc, size_t __bufsiz>
void
_Deque_base<_Tp,_Alloc,__bufsiz>::_M_create_nodes(_Tp** __nstart,
                                                  _Tp** __nfinish)
{
  _Tp** __cur;
  __STL_TRY {
    for (__cur = __nstart; __cur < __nfinish; ++__cur)
      *__cur = _M_map_size.allocate(__buf_traits::_buf_size);
  }
  __STL_UNWIND(_M_destroy_nodes(__nstart, __cur));
}

template <class _Tp, class _Alloc, size_t __bufsiz>
void 
_Deque_base<_Tp,_Alloc,__bufsiz>::_M_destroy_nodes(_Tp** __nstart,
                                                   _Tp** __nfinish)
{
  for (_Tp** __n = __nstart; __n < __nfinish; ++__n)
    _M_map_size.deallocate(*__n, __buf_traits::_buf_size);
}



// Non-inline member functions

# if defined ( __STL_NESTED_TYPE_PARAM_BUG )
// qualified references 
#   define __iterator__           _Deque_iterator<_Tp, _Nonconst_traits<_Tp>, _Buf_size_traits<_Tp, __bufsiz> >
#   define const_iterator         _Deque_iterator<_Tp, _Const_traits<_Tp>, _Buf_size_traits<_Tp, __bufsiz> > 
#   define iterator               __iterator__
#   define size_type              size_t
#   define value_type             _Tp
# else
#  define __iterator__           __STL_TYPENAME_ON_RETURN_TYPE deque<_Tp, _Alloc, __bufsiz>::iterator
# endif

template <class _Tp, class _Alloc, size_t __bufsiz>
deque<_Tp, _Alloc, __bufsiz>&  
deque<_Tp, _Alloc, __bufsiz>::operator= (const deque<_Tp, _Alloc, __bufsiz>& __x) {
  const size_type __len = size();
  if (&__x != this) {
    if (__len >= __x.size())
      erase(copy(__x.begin(), __x.end(), _M_start), _M_finish);
    else {
      const_iterator __mid = __x.begin() + difference_type(__len);
      copy(__x.begin(), __mid, _M_start);
      insert(_M_finish, __mid, __x.end());
    }
  }
  __stl_debug_do(_Invalidate_all());
  return *this;
}        

template <class _Tp, class _Alloc, size_t __bufsiz>
void 
deque<_Tp, _Alloc, __bufsiz>::_M_fill_insert(iterator __pos,
					     size_type __n, const value_type& __x)
{
  __stl_debug_check(__check_if_owner(&_M_iter_list, __pos));
  if (__pos._M_cur == _M_start._M_cur) {
    iterator __new_start = _M_reserve_elements_at_front(__n);
    __STL_TRY {
      uninitialized_fill(__new_start, _M_start, __x);
    }
    __STL_UNWIND(_M_destroy_nodes(__new_start._M_node, _M_start._M_node));
    _M_start = __new_start;
    __stl_debug_do(_M_orphan_start());
  }
  else if (__pos._M_cur == _M_finish._M_cur) {
    iterator __new_finish = _M_reserve_elements_at_back(__n);
    __STL_TRY {
      uninitialized_fill(_M_finish, __new_finish, __x);
    }
    __STL_UNWIND(_M_destroy_nodes(_M_finish._M_node+1, __new_finish._M_node+1));
    _M_finish = __new_finish;
    __stl_debug_do(_M_orphan_finish());
  }
  else 
    _M_insert_aux(__pos, __n, __x);
}

#ifndef __STL_MEMBER_TEMPLATES  

template <class _Tp, class _Alloc, size_t __bufsiz>
void deque<_Tp, _Alloc, __bufsiz>::insert(iterator __pos,
                                           const value_type* __first,
                                           const value_type* __last) {
  __stl_debug_check(__check_if_owner(&_M_iter_list, __pos));
  size_type __n = __last - __first;
  if (__pos._M_cur == _M_start._M_cur) {
    iterator __new_start = _M_reserve_elements_at_front(__n);
    __STL_TRY {
      uninitialized_copy(__first, __last, __new_start);
    }
    __STL_UNWIND(_M_destroy_nodes(__new_start._M_node, _M_start._M_node));
    _M_start = __new_start;
    __stl_debug_do(_M_orphan_start());
  }
  else if (__pos._M_cur == _M_finish._M_cur) {
    iterator __new_finish = _M_reserve_elements_at_back(__n);
    __STL_TRY {
      uninitialized_copy(__first, __last, _M_finish);
    }
    __STL_UNWIND(_M_destroy_nodes(_M_finish._M_node + 1, 
                                  __new_finish._M_node + 1));
    _M_finish = __new_finish;
    __stl_debug_do(_M_orphan_finish());
  }
  else
    _M_insert_aux(__pos, __first, __last, __n);
}

template <class _Tp, class _Alloc, size_t __bufsiz>
void deque<_Tp,_Alloc,__bufsiz>::insert(iterator __pos,
                                         const_iterator __first,
                                         const_iterator __last)
{
  __stl_debug_check(__check_if_owner(&_M_iter_list, __pos));
  size_type __n = __last - __first;
  if (__pos._M_cur == _M_start._M_cur) {
    iterator __new_start = _M_reserve_elements_at_front(__n);
    __STL_TRY {
      uninitialized_copy(__first, __last, __new_start);
    }
    __STL_UNWIND(_M_destroy_nodes(__new_start._M_node, _M_start._M_node));
    _M_start = __new_start;
    __stl_debug_do(_M_orphan_start());
  }
  else if (__pos._M_cur == _M_finish._M_cur) {
    iterator __new_finish = _M_reserve_elements_at_back(__n);
    __STL_TRY {
      uninitialized_copy(__first, __last, _M_finish);
    }
    __STL_UNWIND(_M_destroy_nodes(_M_finish._M_node + 1,__new_finish._M_node + 1));
    _M_finish = __new_finish;
    __stl_debug_do(_M_orphan_finish());
  }
  else
    _M_insert_aux(__pos, __first, __last, __n);
}

#endif /* __STL_MEMBER_TEMPLATES */

template <class _Tp, class _Alloc, size_t __bufsiz>
__iterator__ 
deque<_Tp,_Alloc,__bufsiz>::erase(iterator __first, iterator __last)
{
  __stl_debug_check(__check_if_owner(&_M_iter_list, __first) && __check_range(__first,__last));
  if (__first == _M_start && __last == _M_finish) {
    clear();
    return _M_finish;
  }
  else {
    difference_type __n = __last - __first;
    difference_type __elems_before = __first - _M_start;
    if (__elems_before < difference_type(size() - __n) / 2) {
      copy_backward(_M_start, __first, __last);
      iterator __new_start = _M_start + __n;
      destroy(_M_start, __new_start);
      _M_destroy_nodes(__new_start._M_node, _M_start._M_node);
      _M_start = __new_start;
      __stl_debug_do(_M_orphan_start());
    }
    else {
      copy(__last, _M_finish, __first);
      iterator __new_finish = _M_finish - __n;
      destroy(__new_finish, _M_finish);
      _M_destroy_nodes(__new_finish._M_node + 1, _M_finish._M_node + 1);
      _M_finish = __new_finish;
      __stl_debug_do(_M_orphan_finish());
    }
    return _M_start + __elems_before;
  }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
免费高清在线视频一区·| 亚洲va韩国va欧美va精品 | 欧美激情艳妇裸体舞| 精品国产区一区| 欧美一区二区三区日韩视频| 91精品视频网| 69久久夜色精品国产69蝌蚪网| 欧美乱妇15p| 欧美一激情一区二区三区| 日韩欧美中文字幕一区| 久久这里只有精品首页| 精品国产精品一区二区夜夜嗨| 久久一区二区视频| 久久久三级国产网站| 国产精品国产a| 亚洲免费观看高清完整版在线 | 91在线视频播放地址| www.久久精品| 日本韩国视频一区二区| 欧美日韩国产综合视频在线观看| 91精品福利在线一区二区三区| 欧美不卡一区二区| 国产精品久久久久影院老司| 亚洲综合图片区| 日本va欧美va欧美va精品| 国产精品18久久久久久久久久久久| 国产成+人+日韩+欧美+亚洲| 一本到一区二区三区| 6080午夜不卡| 国产三级三级三级精品8ⅰ区| 中文字幕在线不卡一区二区三区| 亚洲1区2区3区视频| 国产精品一级黄| 色八戒一区二区三区| 日韩美一区二区三区| 亚洲欧美日韩国产另类专区| 美女脱光内衣内裤视频久久网站| 粉嫩一区二区三区在线看| 在线看国产一区| 26uuu国产一区二区三区| 一区二区三区加勒比av| 国产麻豆9l精品三级站| 精品污污网站免费看| 国产精品嫩草久久久久| 日本欧洲一区二区| 91在线视频免费91| 国产视频一区在线播放| 丝袜a∨在线一区二区三区不卡| 国产成人av福利| 欧美一级久久久久久久大片| 亚洲黄网站在线观看| 国产精品一卡二卡在线观看| 91精品国产综合久久久久久漫画 | 91麻豆swag| 精品国产免费一区二区三区香蕉| 一区二区三区四区在线| 国产69精品久久久久毛片| 欧美一级日韩一级| 午夜一区二区三区视频| 在线观看三级视频欧美| 国产精品久久精品日日| 国产 日韩 欧美大片| 欧美成人免费网站| 日韩精品福利网| 欧美群妇大交群中文字幕| 亚洲乱码中文字幕| www.亚洲国产| 国产日韩欧美高清在线| 国产精品99久久久久久久vr | 亚洲三级视频在线观看| 国产超碰在线一区| 亚洲精品一区二区三区蜜桃下载| 奇米色777欧美一区二区| 欧美三区免费完整视频在线观看| 亚洲精品日日夜夜| 欧美最猛黑人xxxxx猛交| 一区二区三区蜜桃网| 在线观看国产精品网站| 亚洲成人在线网站| 欧美日韩不卡一区二区| 日本成人在线看| 日韩你懂的在线播放| 九色综合国产一区二区三区| 日韩一卡二卡三卡| 国产呦萝稀缺另类资源| 国产精品欧美极品| 99久久伊人精品| 亚洲国产视频直播| 正在播放亚洲一区| 捆绑紧缚一区二区三区视频| 日韩欧美美女一区二区三区| 国产黄人亚洲片| **性色生活片久久毛片| 在线一区二区三区四区五区| 五月婷婷久久综合| 精品剧情在线观看| 国产成人精品免费网站| 亚洲欧美日韩小说| 91精品免费在线观看| 国内精品伊人久久久久av影院 | 国产亲近乱来精品视频| 色88888久久久久久影院按摩| 一区二区三区在线观看欧美| 日韩三级精品电影久久久| 九色综合国产一区二区三区| 国产精品高潮呻吟| 欧美日韩在线电影| 国产在线视频不卡二| 亚洲免费在线观看| 欧美一区二区在线播放| 高清在线不卡av| 五月婷婷综合网| 中文字幕的久久| 欧美日韩亚洲另类| 国产91丝袜在线观看| 亚洲一区在线观看网站| 国产欧美日韩在线| 日韩一级精品视频在线观看| 91网站最新网址| 激情欧美一区二区三区在线观看| 一区二区三区久久久| 欧美高清在线一区| 欧美一区二区三级| 在线观看精品一区| 国产iv一区二区三区| 人人爽香蕉精品| 亚洲综合免费观看高清完整版在线 | 久久se这里有精品| 亚洲成人av免费| 亚洲精品中文字幕在线观看| 久久久91精品国产一区二区精品 | 在线不卡一区二区| 99精品视频在线播放观看| 国产一区二区精品在线观看| 首页亚洲欧美制服丝腿| 亚洲精品免费在线观看| 国产日韩欧美一区二区三区综合 | 国产精品少妇自拍| 精品国产乱码久久久久久牛牛| 欧美性极品少妇| 色av成人天堂桃色av| 99久久99精品久久久久久| 成人深夜在线观看| 精品一二三四在线| 精品亚洲porn| 另类人妖一区二区av| 麻豆国产精品一区二区三区 | 欧美吞精做爰啪啪高潮| 99re热这里只有精品视频| 国产成人在线视频网站| 韩国成人福利片在线播放| 免费成人深夜小野草| 精品制服美女丁香| 国产一区二区三区精品视频| 国产精品原创巨作av| 国产一区二区剧情av在线| 国产福利91精品| 成人av网站大全| 91在线视频播放地址| 色狠狠一区二区| 777欧美精品| 日韩欧美一区电影| 久久久久久久久一| 日韩美女啊v在线免费观看| 亚洲人成人一区二区在线观看| 一区二区三区四区中文字幕| 偷拍一区二区三区四区| 日韩电影在线观看一区| 精品一区二区三区香蕉蜜桃| 国产激情一区二区三区四区| a级高清视频欧美日韩| 色久综合一二码| 日韩欧美亚洲国产另类| 久久精品免费在线观看| 中文字幕一区二区在线观看 | 国产一区三区三区| 成人国产精品免费| 91国产丝袜在线播放| 日韩美女天天操| 国产精品久线在线观看| 亚洲电影激情视频网站| 国产一区亚洲一区| 91麻豆成人久久精品二区三区| 欧美区一区二区三区| 国产清纯在线一区二区www| 亚洲综合精品自拍| 国产一区二区成人久久免费影院 | 成人精品亚洲人成在线| 在线精品视频小说1| 精品国产露脸精彩对白| 一区二区三区小说| 韩国三级电影一区二区| 欧美午夜寂寞影院| 国产丝袜在线精品| 日产国产高清一区二区三区| av在线一区二区三区| 精品免费视频.| 亚洲国产aⅴ成人精品无吗| 成人免费毛片高清视频| 91精品欧美久久久久久动漫|