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

📄 stl_vector.h

📁 STL完整源码,实现STL文件的读写和三维体的重建及其分析
💻 H
📖 第 1 页 / 共 2 页
字号:
                    input_iterator_tag);  template <class ForwardIterator>  void range_insert(iterator pos,                    ForwardIterator first, ForwardIterator last,                    forward_iterator_tag);#endif /* __STL_MEMBER_TEMPLATES */};template <class T, class Alloc>inline bool operator==(const vector<T, Alloc>& x, const vector<T, Alloc>& y) {  return x.size() == y.size() && equal(x.begin(), x.end(), y.begin());}template <class T, class Alloc>inline bool operator<(const vector<T, Alloc>& x, const vector<T, Alloc>& y) {  return lexicographical_compare(x.begin(), x.end(), y.begin(), y.end());}#ifdef __STL_FUNCTION_TMPL_PARTIAL_ORDERtemplate <class T, class Alloc>inline void swap(vector<T, Alloc>& x, vector<T, Alloc>& y) {  x.swap(y);}#endif /* __STL_FUNCTION_TMPL_PARTIAL_ORDER */template <class T, class Alloc>vector<T, Alloc>& vector<T, Alloc>::operator=(const vector<T, Alloc>& x) {  if (&x != this) {    if (x.size() > capacity()) {      iterator tmp = allocate_and_copy(x.end() - x.begin(),                                       x.begin(), x.end());      destroy(start, finish);      deallocate();      start = tmp;      end_of_storage = start + (x.end() - x.begin());    }    else if (size() >= x.size()) {      iterator i = copy(x.begin(), x.end(), begin());      destroy(i, finish);    }    else {      copy(x.begin(), x.begin() + size(), start);      uninitialized_copy(x.begin() + size(), x.end(), finish);    }    finish = start + x.size();  }  return *this;}template <class T, class Alloc>void vector<T, Alloc>::insert_aux(iterator position, const T& x) {  if (finish != end_of_storage) {    construct(finish, *(finish - 1));    ++finish;    T x_copy = x;    copy_backward(position, finish - 2, finish - 1);    *position = x_copy;  }  else {    const size_type old_size = size();    const size_type len = old_size != 0 ? 2 * old_size : 1;    iterator new_start = data_allocator::allocate(len);    iterator new_finish = new_start;    __STL_TRY {      new_finish = uninitialized_copy(start, position, new_start);      construct(new_finish, x);      ++new_finish;      new_finish = uninitialized_copy(position, finish, new_finish);    }#       ifdef  __STL_USE_EXCEPTIONS     catch(...) {      destroy(new_start, new_finish);       data_allocator::deallocate(new_start, len);      throw;    }#       endif /* __STL_USE_EXCEPTIONS */    destroy(begin(), end());    deallocate();    start = new_start;    finish = new_finish;    end_of_storage = new_start + len;  }}template <class T, class Alloc>void vector<T, Alloc>::insert(iterator position, size_type n, const T& x) {  if (n != 0) {    if (size_type(end_of_storage - finish) >= n) {      T x_copy = x;      const size_type elems_after = finish - position;      iterator old_finish = finish;      if (elems_after > n) {        uninitialized_copy(finish - n, finish, finish);        finish += n;        copy_backward(position, old_finish - n, old_finish);        fill(position, position + n, x_copy);      }      else {        uninitialized_fill_n(finish, n - elems_after, x_copy);        finish += n - elems_after;        uninitialized_copy(position, old_finish, finish);        finish += elems_after;        fill(position, old_finish, x_copy);      }    }    else {      const size_type old_size = size();              const size_type len = old_size + max(old_size, n);      iterator new_start = data_allocator::allocate(len);      iterator new_finish = new_start;      __STL_TRY {        new_finish = uninitialized_copy(start, position, new_start);        new_finish = uninitialized_fill_n(new_finish, n, x);        new_finish = uninitialized_copy(position, finish, new_finish);      }#         ifdef  __STL_USE_EXCEPTIONS       catch(...) {        destroy(new_start, new_finish);        data_allocator::deallocate(new_start, len);        throw;      }#         endif /* __STL_USE_EXCEPTIONS */      destroy(start, finish);      deallocate();      start = new_start;      finish = new_finish;      end_of_storage = new_start + len;    }  }}#ifdef __STL_MEMBER_TEMPLATEStemplate <class T, class Alloc> template <class InputIterator>void vector<T, Alloc>::range_insert(iterator pos,                                    InputIterator first, InputIterator last,                                    input_iterator_tag) {  for ( ; first != last; ++first) {    pos = insert(pos, *first);    ++pos;  }}template <class T, class Alloc> template <class ForwardIterator>void vector<T, Alloc>::range_insert(iterator position,                                    ForwardIterator first,                                    ForwardIterator last,                                    forward_iterator_tag) {  if (first != last) {    size_type n = 0;    distance(first, last, n);    if (size_type(end_of_storage - finish) >= n) {      const size_type elems_after = finish - position;      iterator old_finish = finish;      if (elems_after > n) {        uninitialized_copy(finish - n, finish, finish);        finish += n;        copy_backward(position, old_finish - n, old_finish);        copy(first, last, position);      }      else {        ForwardIterator mid = first;        advance(mid, elems_after);        uninitialized_copy(mid, last, finish);        finish += n - elems_after;        uninitialized_copy(position, old_finish, finish);        finish += elems_after;        copy(first, mid, position);      }    }    else {      const size_type old_size = size();      const size_type len = old_size + max(old_size, n);      iterator new_start = data_allocator::allocate(len);      iterator new_finish = new_start;      __STL_TRY {        new_finish = uninitialized_copy(start, position, new_start);        new_finish = uninitialized_copy(first, last, new_finish);        new_finish = uninitialized_copy(position, finish, new_finish);      }#         ifdef __STL_USE_EXCEPTIONS      catch(...) {        destroy(new_start, new_finish);        data_allocator::deallocate(new_start, len);        throw;      }#         endif /* __STL_USE_EXCEPTIONS */      destroy(start, finish);      deallocate();      start = new_start;      finish = new_finish;      end_of_storage = new_start + len;    }  }}#else /* __STL_MEMBER_TEMPLATES */template <class T, class Alloc>void vector<T, Alloc>::insert(iterator position,                               const_iterator first,                               const_iterator last) {  if (first != last) {    size_type n = 0;    distance(first, last, n);    if (size_type(end_of_storage - finish) >= n) {      const size_type elems_after = finish - position;      iterator old_finish = finish;      if (elems_after > n) {        uninitialized_copy(finish - n, finish, finish);        finish += n;        copy_backward(position, old_finish - n, old_finish);        copy(first, last, position);      }      else {        uninitialized_copy(first + elems_after, last, finish);        finish += n - elems_after;        uninitialized_copy(position, old_finish, finish);        finish += elems_after;        copy(first, first + elems_after, position);      }    }    else {      const size_type old_size = size();      const size_type len = old_size + max(old_size, n);      iterator new_start = data_allocator::allocate(len);      iterator new_finish = new_start;      __STL_TRY {        new_finish = uninitialized_copy(start, position, new_start);        new_finish = uninitialized_copy(first, last, new_finish);        new_finish = uninitialized_copy(position, finish, new_finish);      }#         ifdef __STL_USE_EXCEPTIONS      catch(...) {        destroy(new_start, new_finish);        data_allocator::deallocate(new_start, len);        throw;      }#         endif /* __STL_USE_EXCEPTIONS */      destroy(start, finish);      deallocate();      start = new_start;      finish = new_finish;      end_of_storage = new_start + len;    }  }}#endif /* __STL_MEMBER_TEMPLATES */#if defined(__sgi) && !defined(__GNUC__) && (_MIPS_SIM != _MIPS_SIM_ABI32)#pragma reset woff 1174#endif__STL_END_NAMESPACE #endif /* __SGI_STL_INTERNAL_VECTOR_H */// Local Variables:// mode:C++// End:

⌨️ 快捷键说明

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