该vector只能容纳标准库中string类,

直接上代码了,StrVec.h文件内容为:

 #ifndef STRVEC_H
#define STRVEC_H #include<iostream>
#include<string>
#include<memory>
using namespace std;
class StrVec{
public:
// 默认构造函数
StrVec():elements(nullptr),first_free(nullptr),cap(nullptr)
{ }
//拷贝构造函数
StrVec(const StrVec& );
//拷贝赋值运算符
StrVec& operator=(const StrVec&);
~StrVec();
void push_back(const string&);
size_t size() const { return first_free - elements ; }
size_t capacity() const { return cap - elements ;}
string* begin() const { return elements ;}
string* end() const { return first_free ;} private:
static allocator<string> alloc; // 分配元素
// 被添加的元素的函数使用
void chk_n_alloc()
{
if( size() == capacity() )
reallocate(); }
// 工具函数,被拷贝构造函数、赋值运算符和析构函数所使用
pair<string* ,string*> alloc_n_copy(const string* ,const string* ); void free();
void reallocate();
string* elements; // 指向数组首元素的指针
string* first_free; // 指向数组第一个空闲元素的指针
string* cap; // 指向数组尾后的指针 }; #endif

StrVec.cpp文件内容为:

 #include "StrVec.h"

 std::allocator<string> StrVec::alloc;

 void StrVec::push_back( const string& s )
{
chk_n_alloc(); // 确保有空间容纳新元素
// first_free指向的元素中构造s的副本
alloc.construct(first_free++,s) ; }
pair<string* ,string* > StrVec::alloc_n_copy(const string* b, const string* e )
{
auto data = alloc.allocate(e-b);
return make_pair(data , uninitialized_copy(b,e,data) ); }
void StrVec::free()
{
// 不能传递给deallcoate一个空指针
if( elements)
{
for(auto p = first_free ; p != elements ; )
alloc.destroy(--p);
alloc.deallocate(elements,cap-elements) ;
} }
StrVec& StrVec::operator=( const StrVec& rhs )
{
auto data = alloc_n_copy(rhs.begin() , rhs.end() );
free() ;
elements = data.first ;
first_free= cap=data.second; return *this ; }
void StrVec::reallocate()
{
// 我们将分配当前大小两倍的内存空间;
auto newcapacity = size() ? *size() : ;
//分配新内存
auto newdata = alloc.allocate( newcapacity ) ; auto dest=newdata ;
auto elem = elements ;
for(size_t i=; i != size() ; i++)
alloc.construct(dest++,std::move( *elem++) );
free();
elements = newdata;
first_free = dest ;
cap = elements+ newcapacity ; }
StrVec::~StrVec()
{
free();
}

测试代码为maintest.cpp

 #include "StrVec.h"

 int main()
{
StrVec vec1;
vec1.push_back("ok1");
vec1.push_back("ok2"); auto begin = vec1.begin();
auto end= vec1.end(); while( begin != end )
{
cout<<*begin<<endl;
// cout<<endl;
begin++; } return ;
}

C++中STL中简单的Vector的实现的更多相关文章

  1. c++中STL中的next_permutation函数基本用法

    对于next_permutation函数是针对于排列组合问题的库函数,它的排序方式是按照字典的方式排列的·: 如以下代码对于next_permutation函数的初步解释: #include<c ...

  2. C++的STL中vector内存分配方法的简单探索

    STL中vector什么时候会自动分配内存,又是怎么分配的呢? 环境:Linux  CentOS 5.2 1.代码 #include <vector> #include <stdio ...

  3. C++ STL中vector(向量容器)使用简单介绍

    原文:http://www.seacha.com/article.php/knowledge/cbase/2013/0903/2205.html C++ vector(向量容器)是一个线性顺序结构.相 ...

  4. C++STL中的vector的简单实用

    [原创] 使用C++STL中的vector, #include <stdio.h> #include<stdlib.h> #include<vector> usin ...

  5. DLL中传递STL参数(如Vector或者list等)会遇到的问题[转载]

    最近的一个项目中遇到了调用别人的sdk接口(dll库)而传给我的是一个vector指针,用完之后还要我来删除的情况.这个过程中首先就是在我的exe中将其vector指针转为相应指针再获取vector中 ...

  6. STL中vector的赋值,遍历,查找,删除,自定义排序——sort,push_back,find,erase

    今天学习网络编程,那个程序中利用了STL中的sort,push_back,erase,自己没有接触过,今天学习一下,写了一个简单的学习程序.编译环境是VC6.0         这个程序使用了vect ...

  7. STL中vector、list、deque和map的区别

    1 vector     向量 相当于一个数组    在内存中分配一块连续的内存空间进行存储.支持不指定vector大小的存储.STL内部实现时,首先分配一个非常大的内存空间预备进行存储,即capac ...

  8. 【转】STL中vector、list、deque和map的区别

    1.vector 向量 相当于一个数组 在内存中分配一块连续的内容空间进行存储.支持不指定vector大小的存储.STL内部实现时,首先分配一个非常大的内存空间预备进行存储,即capacity()函数 ...

  9. STL中的Vector相关用法

    STL中的Vector相关用法 标准库vector类型使用需要的头文件:#include <vector>. vector 是一个类模板,不是一种数据类型,vector<int> ...

随机推荐

  1. React 引入import React 原理

    本质上来说JSX是React.createElement(component, props, ...children)方法的语法糖. 所以我们如果使用了JSX,我们其实就是在使用React,所以我们就 ...

  2. pipelinewise 学习二 创建一个简单的pipeline

    pipelinewise 提供了方便的创建简单pipeline的命令,可以简化pipeline 的创建,同时也可以帮我们学习 生成demo pipeline pipelinewise init --n ...

  3. fpm 打包跨平台rpm 包的一个问题

    平时我们开发机器可能使用的是mac 系统,但是部署机器kennel是linux,默认会有一个操作系统的问题, 我们可以在打包的时候指定os版本信息 参考 --rpm-os linux 参考例子 一个构 ...

  4. uni-app 事件以及事件绑定

    事件修饰符stop的使用会阻止冒泡,但是同时绑定了一个非冒泡的事件,会导致该元素上的catchEventName失效! prevent可以直接干掉,因为uni-app里没有什么默认事件,比如submi ...

  5. [NOIP2013]华容道 题解

    [NOIP2013]华容道 首先是一种比较显然的做法. 整个棋盘,除了起点,终点和空格,其他的方块是等价的. 对于终点,它始终不会变化,如果搜到终点结束搜索即可,所以我们不需要考虑终点. 所以需要考虑 ...

  6. [BUAA软工]提问回顾与个人总结

    提问回顾与个人总结 项目 内容 所属课程 2019春季计算机学院软件工程(任健) 所属作业 提问回顾与问题总结 课程目标 理解软件工程的作用和重要性,提升工程能力,团队协作能力 作业目标 回顾软工课程 ...

  7. 【转】Linux下的CPU使用率与服务器负载的关系与区别

    当我们使用top命令查看系统的资源使用情况时会看到load average,如下图所示,它表示系统在1,5,15分钟的平均工作负载. 那么什么是负载(load)呢?它和CPU的利用率又有什么关系呢? ...

  8. Mercurial 安装及使用

      版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/moonspiritacm/articl ...

  9. How To Wake Up at 5 A.M. Every Day

    How To Wake Up at 5 A.M. Every Day For the past 3 months, I’ve successfully transitioned into being ...

  10. HTML5快速写页面的方法

    1 如果有原型的HTML页面(Axure导出来),可以在此从F12的“查看器”基础上拷贝到一个新文件,继续写代码. 2 利用EditPlus软件的工具 3 使用Dreamweaver CS5,可以直观 ...