初识C++ Vector模板与实例化原理

目录
  • 引言
  • Vector
  • 模板与实例化
  • 性能

引言

之前学了字符串,字符,数字这些类型,字符串可以看出包含多个字符的序列,那么包含多个数字的序列该是啥,包含其他类型的呢,c++当中满足这个需求是vector,我们一起来看看吧。

Vector

标准库类型vector表述对象的集合,可以看成一个存放其他对象的容器,但是这里要注意的是同一个vector集合当中智能容纳一个类型,容器里面的元素都有一一对应的索引,可以通过索引访问元素。当然,vector是标准库类型,使用需要使用加载,代码如下:

#include <iostream>
#include <vector>
int main(){
   using namespace std;
   vector<int> vec01;
   vector<int> vec02(4);
   vector<int> vec03(4, 10);
   vector<int> vec04(vec04.begin(),vec04.end());
   return 0;
}

当然这里用到了vector的的一些方法,begin,end,这些会在后面再聊聊。

模板与实例化

上面是代码层面的一个简单了解,接下来聊聊发生了什么?

这里首先要明确一个点,vector不是一个对象,而是创建对象的一个配置,可以称为模板,而vector是类模板,当然也有函数模板,具体来看模板的话,首先要知道,我们再开发的过程当中可能用到函数,可能用到类,通常情况下需要先定义,再使用,但是有没有可能动态的去声明一个类呢,比如:

vector <int> vec01; //定义一个数字类型的容器
vector <string> veco2; //定义一个字符串类型的容器

这种情况下,两行代码用的都是vector,但是一个创建的是数字容器,一个创建的是string容器,那么vector的作用就不是一个对象,而是定义一个对象。至于int vec01,string vec02这些都是他定义一个对象过程当中的配置,那么把这样的东西叫做模板(有点类型Python当中的元类,嘿嘿嘿,好久没有更新Python的知识点了,差点忘记自己是一个Python开发。)。

而通过模板,提供配置,生成具体对象的过程,我们称为实例化的过程,个人理解就是通过vector的一个规则,生成一个具体实实在在存在的容器的过程。

性能

好吧,往深处聊聊,我们看一下vector的性能,这些小白基本的小伙伴一定要以理解为主:

vector作为一种容器有点类似数组,但它的大小可以动态改变,所以可以称它位动态数组。

和数组一样,vector的元素在内存中连续排列,那么就可以通过指针的偏移来获取vector中的元素,读取效率会很高。

但是完事儿由利必有弊,连续再查询上是由优势的,但是如果要插入元素的话,尤其是中间插入,整个vector的size变大,在内存中就需要重新分配空间,常规的做法是直接申请一个新的array,并将所有元素拷贝过去;但这么做的话,无疑太浪费时间,因此vector采用的做法是:vector会分配额外的空间,以适应size的动态增长。因此,包含同样数量元素的vector和数组相比,占用的空间会更大。

转折一下,在vector最后增加或者删除一个元素,消耗的时间是一个常数值,与vector的size无关。

与其他容器相比,vector在获取元素和对最后一个元素的操作效率上更高;

但对于中间元素的操作,性能则相对较差。

以上就是初识C++ Vector模板与实例化原理的详细内容,更多关于C++ Vector模板实例化的资料请关注我们其它相关文章!

(0)

相关推荐

  • C++超详细讲解模板的使用

    目录 一.函数模板 1.1函数模板概念 1.2 函数模板格式 1.3 函数模板的原理 1.4 函数模板的实例化 二.类模板 2.1 类模板的定义格式 2.2类模板的实例化 总结 一.函数模板 1.1函数模板概念 函数模板代表了一个函数家族,该函数模板与类型无关,在使用时被参数化,根据实参类型产生函数的特定类型版本. 1.2 函数模板格式 template<typename T1, typename T2,…,typename Tn> 返回值类型 函数名(参数列表){} template<

  • C++函数模板的使用详解

    函数模板可以适用泛型来定义函数,其中泛型可以是(int, double, float)等替换.在函数重载过程中,通过将类型作为参数传递给模板,可使编译器自动产生该类型的函数. 工作原理:比如需要定义一个比大小的max函数,有三种类型的数据(int,double,float),可能就需要编写三个函数,这样既浪费时间,且容易出错.如: #include <iostream> using namespace std; int Max(int a, int b); double Max(double

  • C++ 类模板与成员函数模板示例解析

    目录 类模板 类模板与成员函数模板的区别 类模板 前面以函数模板为例,介绍了具体化与实例化.那么对于类模板,有什么不同呢? 类包括成员变量和成员函数,他们都可以包含类模板的模板参数.而成员函数本身也可以是函数模板.看下面的两个类: // 类模板 template <typename T> class A { private: T t; public: void funcA(T t); }; template <typename T> void A<T>::funcA(T

  • C++模板以及实现vector实例详解

    目录 函数模板 类模板 Vector实现 简单的类模板实现代码及测试: win msvc编译器的实现: 容器的空间配置器 运算符重载与迭代器实现 最终vector的实现代码 总结 函数模板 函数模板:是不进行编译的,因为类型还不知道 模板的实例化:函数调用点进行实例化 模板函数:才是要被编译器所编译的 模板类型参数:typyname/class 模板非类型参数:模板非类型形参的详细阐述 模板的实参推演:可以根据用户传入的实参的类型,来推导出模板类型参数的具体 模板的特例化(专用化)的实例化 模板

  • C++模板 index_sequence使用示例详解

    目录 引言 integer_sequence index_sequence make_index_sequence 使用场景 index_sequence_for 结语 引言 integer_sequence 是 c++ 14中新增加的一个元编程工具 其衍生出来的还有如 index_sequence.make_index_sequence.index_sequence_for等辅助工具 现在,让我们来浅尝一下这些东西吧! integer_sequence integer_sequence 其实没

  • C++将模板实现放入头文件原理解析

    目录 写在前面 例子 原因 分析 解决方案 方案一 方案二 参考 写在后面 写在前面 本文通过实例分析与讲解,解释了为什么C++一般将模板实现放在头文件中.这主要与C/C++的编译机制以及C++模板的实现原理相关,详情见正文.同时,本文给出了不将模板实现放在头文件中的解决方案. 例子 现有如下3个文件: // add.h template <typename T> T Add(const T &a, const T &b); // add.cpp #include "

  • 初识C++ Vector模板与实例化原理

    目录 引言 Vector 模板与实例化 性能 引言 之前学了字符串,字符,数字这些类型,字符串可以看出包含多个字符的序列,那么包含多个数字的序列该是啥,包含其他类型的呢,c++当中满足这个需求是vector,我们一起来看看吧. Vector 标准库类型vector表述对象的集合,可以看成一个存放其他对象的容器,但是这里要注意的是同一个vector集合当中智能容纳一个类型,容器里面的元素都有一一对应的索引,可以通过索引访问元素.当然,vector是标准库类型,使用需要使用加载,代码如下: #inc

  • Smarty模板类内部原理实例分析

    本文实例讲述了Smarty模板类内部原理.分享给大家供大家参考,具体如下: 之前在学习ThinkPHP的时候,有接触到Smarty模板类,但是一直不知道其内部实现的原理,博主今天终于知道了其内部原理,其实也挺简单的,然后写了一个迷你版的Smarty模板类,对理解其内部原理有了很大的帮助. 1.迷你版Smarty类 首先上代码,最后再进行讲解. 项目结构图 MiniSmarty类代码(MiniSmarty.class.php) <?php /** * 迷你模板类 */ class MiniSmar

  • 高性能JavaScript模板引擎实现原理详解

    随着 web 发展,前端应用变得越来越复杂,基于后端的 javascript(Node.js) 也开始崭露头角,此时 javascript 被寄予了更大的期望,与此同时 javascript MVC 思想也开始流行起来.javascript 模板引擎作为数据与界面分离工作中最重要一环,越来越受开发者关注,近一年来在开源社区中更是百花齐放,在 Twitter.淘宝网.新浪微博.腾讯QQ空间.腾讯微博等大型网站中均能看到它们的身影. 本文将用最简单的示例代码描述现有的 javascript 模板引擎

  • JavaScript模板引擎实现原理实例详解

    本文实例讲述了JavaScript模板引擎实现原理.分享给大家供大家参考,具体如下: 1.入门实例 首先我们来看一个简单模板: <script type="template" id="template"> <h2> <a href="{{href}}" rel="external nofollow" > {{title}} </a> </h2> <img src

  • springboot学习之Thymeleaf模板引擎及原理介绍

    目录 模板引擎 什么是模板引擎? 模板引擎的原理 引入Thymeleaf Thymeleaf分析 Thymeleaf语法学习 模板引擎 springboot我们目前是以jar包的形式打包,实际上我们之前是打成war包,放到tomcat服务器里面,可以用JSP.但是jar包就导致不能用JSP,换一种方式就是springboot推荐的Thymeleaf模板引擎(JSP也是一种模板引擎,除此之外还有什么framework也是一种模板引擎), 什么是模板引擎? 模板引擎就是解决我们需要动态赋值给前端的一

  • C++STL之vector模板类详解

    目录 前言 vector模板类 创建vector对象,遍历元素 迭代器 容器的基本方法 STL函数,sort 总结 前言 STL标准模板库是C++中非常有用的功能库.本篇从vector容器开始学习STL. vector模板类 创建vector对象,遍历元素 vector模板类在头文件vector中,用于存储数组,并采用动态内存分配. 创建一个vector对象并初始化长度,通过[]运算符访问元素: #include <vector> using namespace std; int main()

  • C++STL教程之vector模板的使用

    目录 vector模板类 1. vector模板类 1.1 创建模板类 1.2 STL容器都提供的成员方法 1.3 vector特有的成员方法 1.4 STL容器的非成员方法 vector模板类 STL(标准模板库)提供了容器.迭代器.函数对象.算法的模板.容器是类似于数组的东西,它可以存储若干值,STL容器是同质的,即存储的值的类型相同;迭代器是用来遍历容器的,它和能遍历数组的指针类似,是广义指针;函数对象是类似于函数的对象,可以是类对象和函数指针;算法就是一些能完成特定任务的处方. 我们来看

  • 这一次搞懂Spring的Bean实例化原理操作

    前言 前两篇文章分析了Spring XML和注解的解析原理,并将其封装为BeanDefinition对象存放到IOC容器中,而这些只是refresh方法中的其中一个步骤--obtainFreshBeanFactory,接下来就将围绕着这些BeanDefinition对象进行一系列的处理,如BeanDefinitionRegistryPostProcessor对象方法的调用.BeanFactoryPostProcessor对象方法的调用以及Bean实例的创建都离不开这些BeanDefinition

  •  C++模板template原理解析

    目录 前言 1. 函数模板 1.1函数模板的概念 1.2函数模板的格式 1.3 函数模板的原理 1.4 函数模板的实例化 1.4.1 隐式实例化 1.4.2 显式实例化 1.5 模板参数的匹配原则 2. 类模板 2.1 类模板的定义格式 2.2 类模板的实例化 前言 在学习模板之前我们首先要了解泛型编程.泛型编程是一种编程风格,其中算法以尽可能抽象的方式编写,而不依赖于将在其上执行这些算法的数据形式.泛型编程只编写与类型无关的通用代码,是代码复用的一种手段.本节学习的模板是泛型编程的基础. 模板

随机推荐