当前位置: 首页 > news >正文

wordpress企业网站主题北京专业做网站公司

wordpress企业网站主题,北京专业做网站公司,刚刚深圳出的大事,黄冈做网站目录 前言1. vector介绍及使用1.1vector的介绍1.2 vector的使用1.2.1 构造函数 1.2.2 vector对象遍历1.2.3 reserve和resize1.2.4 insert和erase 2. vector模拟实现2.1 vector迭代器失效问题2.2 模拟实现reserve函数浅拷贝问题2.3模拟实现源码2.3.1 vector.h2.3.2 test.cpp 前言…

目录

      • 前言
      • 1. vector介绍及使用
        • 1.1vector的介绍
        • 1.2 vector的使用
          • 1.2.1 构造函数
        • 1.2.2 vector对象遍历
        • 1.2.3 reserve和resize
        • 1.2.4 insert和erase
      • 2. vector模拟实现
        • 2.1 vector迭代器失效问题
        • 2.2 模拟实现reserve函数浅拷贝问题
        • 2.3模拟实现源码
          • 2.3.1 vector.h
          • 2.3.2 test.cpp

前言

这篇文章我们来学习一下STL容器里的vector,我们先来学习一下它的使用,然后对vector进行模拟实现。

1. vector介绍及使用

1.1vector的介绍

vector文档介绍

vector是一个大小可以更改的数组序列容器。

在这里插入图片描述
其实这里可以简单认为vector就是之前数据结构学的顺序表。

1.2 vector的使用

vector提供的接口跟string是非常相似的,所以经过前面string的学习,再学习vector成本降低了很多。
在这里插入图片描述
下面我们来介绍一下常用接口

1.2.1 构造函数

在这里插入图片描述
首先看第一个:
在这里插入图片描述
这个是用来传空间配置器的,我们可以认为这个就是无参的构造函数,构造一个空的vector

注意:
vector是一个类模板,类模板实例化只能显式实例化,即需要在类模板名字后跟<>,然后将实例化的类型放在<>中即可。
类模板不是真正的类,其实例化的结果才是真正的类。

在这里插入图片描述

在这里插入图片描述
这个就是支持用n个val构造一个vector对象。
在这里插入图片描述

在这里插入图片描述
这个就是支持迭代器区间构造,也不难理解我们来给大家演示一下:
在这里插入图片描述

在这里插入图片描述这个就是拷贝构造了
在这里插入图片描述

1.2.2 vector对象遍历

在这里插入图片描述
vector也重载了[]这里可以使用for循环遍历:
在这里插入图片描述
也可以使用迭代器,也就是支持范围for:
在这里插入图片描述

1.2.3 reserve和resize

首先我们来看一下vector的扩容机制:

#include <iostream>
#include <vector>
using namespace std;
int main()
{// 测试vector的默认扩容机制size_t sz;vector<int> v;sz = v.capacity();cout << "making v grow:\n";for (int i = 0; i < 100; ++i){v.push_back(i);if (sz != v.capacity()){sz = v.capacity();cout << "capacity changed: " << sz << '\n';}}return 0;
}

这里g++下是二倍扩:
在这里插入图片描述

当我们知道需要多少空间,直接用reserve把空间开好,就可以减少频繁扩容的一个消耗。
在这里插入图片描述
在这里插入图片描述
确定知道需要用多少空间,reserve可以缓解vector增容的代价缺陷问题

我们再来看一下resize():
在这里插入图片描述
resize在开空间的同时还会进行初始化,当然如果传的n比size小,那它还会删除多余的数据。
在这里插入图片描述

1.2.4 insert和erase

与string相比vector只支持我们去传迭代器和迭代器区间了
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2. vector模拟实现

2.1 vector迭代器失效问题

会引起其底层空间改变的操作,都有可能导致迭代器失效,比如:resize、reserve、insert、assign、push_back等。
出错原因:
以上操作,都有可能会导致vector扩容,迭代器失效,实际就是迭代器底层对应指针所指向的空间被销毁了,而使用一块已经被释放的空间,造成的后果是程序崩溃(即如果继续使用已经失效的迭代器,程序可能会崩溃)

这里我们举个简单的例子,以下代码用于输出v1中所有偶数:

int main()
{vector<int> v1;v1.push_back(1);v1.push_back(2);v1.push_back(2);v1.push_back(3);v1.push_back(4);v1.push_back(5);v1.push_back(6);for (auto e : v1){cout << e << " ";}cout << endl;auto it = v1.begin();while(it != v1.end())//错误代码{if(*it % 2 == 0){v1.erase(it);}it++;}// while (it != v1.end())// {//     if (*it % 2 == 0)//     {//         it = v1.erase(it);//     }//     else//     {//         ++it;//     }// }
}

在这里插入图片描述
这里程序会报错出现段错误。实际上这里是因为是因为erase删除pos位置元素后,pos位置之后的元素会往前搬移,他没有接收返回值而是一味的进行++操作导致程序越界奔溃

2.2 模拟实现reserve函数浅拷贝问题

这里主要出现错误的原因就是内部使用了memcpy来拷贝数据。

  1. memcpy是内存的二进制格式拷贝,将一段内存空间中内容原封不动的拷贝到另外一段内存空间中
  2. 如果拷贝的是内置类型的元素,memcpy既高效又不会出错

但如果拷贝的是自定义类型元素,并且
自定义类型元素中涉及到资源管理时,就会出错,因为memcpy的拷贝实际是浅拷贝

我们这里以vector< string >为例:
在这里插入图片描述

2.3模拟实现源码
2.3.1 vector.h
#include<iostream>
#include<assert.h>
using namespace std;namespace w
{template<class T>class vector{public:typedef T* iterator;typedef const T* const_iterator;iterator begin(){return _start;}iterator end(){return _finish;}const_iterator begin() const{return _start;}const_iterator end() const{return _finish;}vector(size_t n, const T& val = T()){resize(n, val);}vector(int n, const T& val = T()){resize(n, val);}// [first, last)template<class InputIterator>vector(InputIterator first, InputIterator last){while (first != last){push_back(*first);++first;}}vector(){}vector(const vector<T>& v){_start = new T[v.capacity()];//memcpy(_start, v._start, sizeof(T)*v.size());for (size_t i = 0; i < v.size(); i++){_start[i] = v._start[i];}_finish = _start + v.size();_endofstorage = _start + v.capacity();}void swap(vector<T>& v){std::swap(_start, v._start);std::swap(_finish, v._finish);std::swap(_endofstorage, v._endofstorage);}vector<T>& operator=(vector<T> v){swap(v);return *this;}~vector(){if (_start){delete[] _start;_start = _finish = _endofstorage = nullptr;}}void reserve(size_t n){if (n > capacity()){size_t sz = size();T* tmp = new T[n];if (_start){//memcpy(tmp, _start, sizeof(T) * sz);for (size_t i = 0; i < sz; i++){tmp[i] = _start[i];}delete[] _start;}_start = tmp;_finish = _start + sz;_endofstorage = _start + n;}}void resize(size_t n, const T& val = T()){if (n < size()){_finish = _start + n;}else{reserve(n);while (_finish != _start + n){*_finish = val;++_finish;}}}void push_back(const T& x){insert(end(), x);}void pop_back(){erase(--end());}size_t capacity() const{return _endofstorage - _start;}size_t size() const{return _finish - _start;}T& operator[](size_t pos){assert(pos < size());return _start[pos];}const T& operator[](size_t pos) const{assert(pos < size());return _start[pos];}iterator insert(iterator pos, const T& x){assert(pos >= _start && pos <= _finish);if (_finish == _endofstorage){size_t len = pos - _start;size_t newcapacity = capacity() == 0 ? 4 : capacity() * 2;reserve(newcapacity);// 解决pos迭代器失效问题pos = _start + len;}iterator end = _finish - 1;while (end >= pos){*(end + 1) = *end;--end;}*pos = x;++_finish;return pos;}iterator erase(iterator pos){assert(pos >= _start && pos < _finish);iterator it = pos + 1;while (it != _finish){*(it - 1) = *it;++it;}--_finish;return pos;}private:iterator _start = nullptr;iterator _finish = nullptr;iterator _endofstorage = nullptr;};}
2.3.2 test.cpp
#include "vector.h"
void test_vector1(){w:: vector<int> v1;v1.push_back(1);v1.push_back(2);v1.push_back(3);v1.push_back(4);v1.push_back(5);for (auto e : v1){cout << e << " ";}cout<<endl;for (size_t i = 0; i < v1.size(); i++){v1[i]++;}for (auto e : v1){cout << e << " ";}cout << endl;}void test_vector2(){w ::vector<int> v1;v1.push_back(1);v1.push_back(2);v1.push_back(3);v1.push_back(4);v1.push_back(5);v1.push_back(5);v1.push_back(5);v1.push_back(5);for (auto e : v1){cout << e << " ";}cout << endl;v1.insert(v1.begin(), 100);for (auto e : v1){cout << e << " ";}cout << endl;}int main()
{test_vector2();return 0;
}
http://www.yayakq.cn/news/347468/

相关文章:

  • 普通网站能不能用vue做几个小功能电商网站前端架构设计
  • 做旅游网站的项目背景4399小游戏网页版入口
  • 建设网站如何进行网站备案做关键词排名卖网站
  • 建网站的支付安全怎么做网站优化
  • 贵阳网站设计找哪家深圳市建设注册执业资格中心网站
  • 贵阳网站建设公司招聘品牌网站建设k小蝌蚪
  • 网上购物最便宜的网站成都集和品牌设计公司
  • 怎么申请网站详细步骤深圳网站建设策划
  • 小学生网站制作Wordpress必备chaj
  • 陕西住房建设厅考试官方网站个体工商户可以备案哪些网站
  • 网站建设信息在哪儿发布网站改版有什么影响
  • 小说网站怎么做推广重庆市建设公共资源交易中心网站首页
  • 网站开发技术简介dwphp英文商城网站建设
  • 网站公司建设个服务号多少钱成都租车公司网站
  • 小说网站建设吧电子商务主要就业方向
  • 网站如何做视频点播平台网站开发风险
  • 建站导航网页设计尺寸1440
  • 网站建设财务处理网站建设公司有哪些重要职务
  • 做网站建设与推广企业三门峡住房城乡建设局网站
  • 合肥网站制作QQ展示型网站建设价格
  • 二七网建站网店设计教程
  • 四川新站优化大数据营销案例分析
  • 做网站的公司不会设计手机报价网站大全
  • 全球做空现货黄金的网站莱芜手机网站建设电话
  • 如何更好的建设和维护网站网站描述怎样写
  • 简单网站建设方案策划白银市建设管理处网站
  • 网站注册搜索引擎的目的是html网页框架代码实例
  • wampserver搭建网站辽阳专业网站开发公司
  • 云南网站设计流程龙岩网站开发
  • 网站加强队伍建设网页设计与制作教程机械工业出版社