⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 _set.h

📁 stl的源码
💻 H
📖 第 1 页 / 共 2 页
字号:
  { return _M_t.equal_range_unique(__x); }};//Specific iterator traits creation_STLP_CREATE_ITERATOR_TRAITS(MultisetTraitsT, Const_traits)template <class _Key, _STLP_DFL_TMPL_PARAM(_Compare, less<_Key>),                      _STLP_DFL_TMPL_PARAM(_Alloc, allocator<_Key>) >class multiset#if defined (_STLP_USE_PARTIAL_SPEC_WORKAROUND)               : public __stlport_class<multiset<_Key, _Compare, _Alloc> >#endif{  typedef multiset<_Key, _Compare, _Alloc> _Self;public:  // typedefs:  typedef _Key     key_type;  typedef _Key     value_type;  typedef _Compare key_compare;  typedef _Compare value_compare;private:  //Specific iterator traits creation  typedef _STLP_PRIV _MultisetTraitsT<value_type> _MultisetTraits;public:  //Following typedef have to be public for __move_traits specialization.  typedef _STLP_PRIV _Rb_tree<key_type, key_compare,                              value_type, _STLP_PRIV _Identity<value_type>,                              _MultisetTraits, _Alloc> _Rep_type;  typedef typename _Rep_type::pointer pointer;  typedef typename _Rep_type::const_pointer const_pointer;  typedef typename _Rep_type::reference reference;  typedef typename _Rep_type::const_reference const_reference;  typedef typename _Rep_type::iterator iterator;  typedef typename _Rep_type::const_iterator const_iterator;  typedef typename _Rep_type::reverse_iterator reverse_iterator;  typedef typename _Rep_type::const_reverse_iterator const_reverse_iterator;  typedef typename _Rep_type::size_type size_type;  typedef typename _Rep_type::difference_type difference_type;  typedef typename _Rep_type::allocator_type allocator_type;private:  _Rep_type _M_t;  // red-black tree representing multiset  _STLP_KEY_TYPE_FOR_CONT_EXT(key_type)public:#if !defined (_STLP_DONT_SUP_DFLT_PARAM)  explicit multiset(const _Compare& __comp = _Compare(),                    const allocator_type& __a = allocator_type())#else  multiset()    : _M_t(_Compare(), allocator_type()) {}  explicit multiset(const _Compare& __comp)    : _M_t(__comp, allocator_type()) {}  multiset(const _Compare& __comp, const allocator_type& __a)#endif    : _M_t(__comp, __a) {}#if defined (_STLP_MEMBER_TEMPLATES)  template <class _InputIterator>  multiset(_InputIterator __first, _InputIterator __last)    : _M_t(_Compare(), allocator_type())    { _M_t.insert_equal(__first, __last); }  template <class _InputIterator>  multiset(_InputIterator __first, _InputIterator __last,           const _Compare& __comp,           const allocator_type& __a _STLP_ALLOCATOR_TYPE_DFL)    : _M_t(__comp, __a) { _M_t.insert_equal(__first, __last); }#  if defined (_STLP_NEEDS_EXTRA_TEMPLATE_CONSTRUCTORS)  template <class _InputIterator>  multiset(_InputIterator __first, _InputIterator __last,           const _Compare& __comp)    : _M_t(__comp, allocator_type()) { _M_t.insert_equal(__first, __last); }#  endif#else  multiset(const value_type* __first, const value_type* __last)    : _M_t(_Compare(), allocator_type())    { _M_t.insert_equal(__first, __last); }  multiset(const value_type* __first, const value_type* __last,           const _Compare& __comp,           const allocator_type& __a = allocator_type())    : _M_t(__comp, __a) { _M_t.insert_equal(__first, __last); }  multiset(const_iterator __first, const_iterator __last)    : _M_t(_Compare(), allocator_type())    { _M_t.insert_equal(__first, __last); }  multiset(const_iterator __first, const_iterator __last,           const _Compare& __comp,           const allocator_type& __a = allocator_type())    : _M_t(__comp, __a) { _M_t.insert_equal(__first, __last); }#endif /* _STLP_MEMBER_TEMPLATES */  multiset(const _Self& __x) : _M_t(__x._M_t) {}  _Self& operator=(const _Self& __x) {    _M_t = __x._M_t;    return *this;  }#if !defined (_STLP_NO_MOVE_SEMANTIC)  multiset(__move_source<_Self> src)    : _M_t(__move_source<_Rep_type>(src.get()._M_t)) {}#endif  // accessors:  key_compare key_comp() const { return _M_t.key_comp(); }  value_compare value_comp() const { return _M_t.key_comp(); }  allocator_type get_allocator() const { return _M_t.get_allocator(); }  iterator begin() { return _M_t.begin(); }  iterator end() { return _M_t.end(); }  const_iterator begin() const { return _M_t.begin(); }  const_iterator end() const { return _M_t.end(); }  reverse_iterator rbegin() { return _M_t.rbegin(); }  reverse_iterator rend() { return _M_t.rend(); }  const_reverse_iterator rbegin() const { return _M_t.rbegin(); }  const_reverse_iterator rend() const { return _M_t.rend(); }  bool empty() const { return _M_t.empty(); }  size_type size() const { return _M_t.size(); }  size_type max_size() const { return _M_t.max_size(); }  void swap(_Self& __x) { _M_t.swap(__x._M_t); }#if defined (_STLP_USE_PARTIAL_SPEC_WORKAROUND) && !defined (_STLP_FUNCTION_TMPL_PARTIAL_ORDER)  void _M_swap_workaround(_Self& __x) { swap(__x); }#endif  // insert/erase  iterator insert(const value_type& __x)  { return _M_t.insert_equal(__x); }  iterator insert(iterator __pos, const value_type& __x)  { return _M_t.insert_equal(__pos, __x); }#if defined (_STLP_MEMBER_TEMPLATES)  template <class _InputIterator>  void insert(_InputIterator __first, _InputIterator __last)  { _M_t.insert_equal(__first, __last); }#else  void insert(const value_type* __first, const value_type* __last)  { _M_t.insert_equal(__first, __last); }  void insert(const_iterator __first, const_iterator __last)  { _M_t.insert_equal(__first, __last); }#endif /* _STLP_MEMBER_TEMPLATES */  void erase(iterator __pos) { _M_t.erase( __pos ); }  size_type erase(const key_type& __x) { return _M_t.erase(__x); }  void erase(iterator __first, iterator __last) { _M_t.erase( __first, __last ); }  void clear() { _M_t.clear(); }  // multiset operations:  _STLP_TEMPLATE_FOR_CONT_EXT  iterator find(const _KT& __x) { return _M_t.find(__x); }  _STLP_TEMPLATE_FOR_CONT_EXT  const_iterator find(const _KT& __x) const { return _M_t.find(__x); }  _STLP_TEMPLATE_FOR_CONT_EXT  size_type count(const _KT& __x) const { return _M_t.count(__x); }  _STLP_TEMPLATE_FOR_CONT_EXT  iterator lower_bound(const _KT& __x) { return _M_t.lower_bound(__x); }  _STLP_TEMPLATE_FOR_CONT_EXT  const_iterator lower_bound(const _KT& __x) const { return _M_t.lower_bound(__x); }  _STLP_TEMPLATE_FOR_CONT_EXT  iterator upper_bound(const _KT& __x) { return _M_t.upper_bound(__x); }  _STLP_TEMPLATE_FOR_CONT_EXT  const_iterator upper_bound(const _KT& __x) const { return _M_t.upper_bound(__x); }  _STLP_TEMPLATE_FOR_CONT_EXT  pair<iterator, iterator> equal_range(const _KT& __x) { return _M_t.equal_range(__x); }  _STLP_TEMPLATE_FOR_CONT_EXT  pair<const_iterator, const_iterator> equal_range(const _KT& __x) const { return _M_t.equal_range(__x); }};#else#  include <stl/pointers/_set.h>_STLP_BEGIN_NAMESPACE#endif /* _STLP_USE_PTR_SPECIALIZATIONS */#define _STLP_TEMPLATE_HEADER template <class _Key, class _Compare, class _Alloc>#define _STLP_TEMPLATE_CONTAINER set<_Key,_Compare,_Alloc>#include <stl/_relops_cont.h>#undef  _STLP_TEMPLATE_CONTAINER#define _STLP_TEMPLATE_CONTAINER multiset<_Key,_Compare,_Alloc>#include <stl/_relops_cont.h>#undef  _STLP_TEMPLATE_CONTAINER#undef  _STLP_TEMPLATE_HEADER#if defined (_STLP_CLASS_PARTIAL_SPECIALIZATION) && !defined (_STLP_NO_MOVE_SEMANTIC)template <class _Key, class _Compare, class _Alloc>struct __move_traits<set<_Key,_Compare,_Alloc> > :  _STLP_PRIV __move_traits_aux<typename set<_Key,_Compare,_Alloc>::_Rep_type>{};template <class _Key, class _Compare, class _Alloc>struct __move_traits<multiset<_Key,_Compare,_Alloc> > :  _STLP_PRIV __move_traits_aux<typename multiset<_Key,_Compare,_Alloc>::_Rep_type>{};#endif_STLP_END_NAMESPACE#endif /* _STLP_INTERNAL_SET_H */// Local Variables:// mode:C++// End:

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -