<vector>头文件里带有两个类型参数的类模板,第一个参数是需要指定的数据类型,第二个是分配器(allocator)类型

template<class T, class Allocator = allocator<T>>   class vector;

用分配器来为元素分配内存和释放内存。需要注意的是vector的运算符operator[] 和方法 at()的区别就是。前者不进行边界检查,而后者进行边界检查,超出边界会抛出out_of_range()的异常;

#include <iostream>
#include <vector>
#include <limits>
int main()
{
std::vector<double> vectorDouble;
//int max = -std::numeric_limits<double>::infinity();
//std::cout << "max : " << max << std::endl; //2^31 = 2147483648;max = -2147483648;
for(int i = ;true;++i)
{
double temp = 0.0;
std::cout << "enter scord(-1 is stop )" << i << ": ";
std::cin >> temp;
if(temp == -)
{
break;
}
vectorDouble.push_back(temp);
// if(temp > max)
// {
// max = temp;
// } } //max /= 100.0;
for(auto &element : vectorDouble)
{
//element = element / max;
std::cout << element << " ";
}
return ;
}

这里的numeric_limits<>模板详见  https://www.cnblogs.com/boost/p/10369272.html

vector的复制和赋值

vector储存对象的副本,其析构函数调用每个对象的析构函数,vector的赋值运算符和复制构造函数对所有的vector元素进行深度复制,处于效率的考虑,因该向函数和方法传递vector的引用或则是const引用。除了普通的复制和赋值外,vector还提供了assign()方法。这个方法可以删除所有的现存的元素,并且添加任意数目的元素;比如:

  

#include <iostream>
#include <vector>
#include <limits>
int main()
{
std::vector<int> oneVector({,,,,});
for(auto temp : oneVector)
{
std::cout << temp << " ";
}
std::cout << std::endl; oneVector.assign(,);
for(auto temp : oneVector)
{
std::cout << temp << " ";
}
return ;
}

结果是:

1 2 3 4 5
10 10 10 10 10

这里用到了初始化列表(<initializer_list>),

vector还有函数swap()方法,这函数交换两个vector对象,前提是这两个vector的类型是一样的。

#include <iostream>
#include <vector>
#include <limits>
int main()
{
std::vector<int> oneVector({,,,,});
//std::vector<int> twoVector({'a','b','c','d','e'});
std::vector<int> twoVector(,);
std::cout << "oneVector : ";
for(auto temp : oneVector)
{
std::cout << temp << " ";
}
std::cout << std::endl;
std::cout << "twoVector : ";
for(auto temp : twoVector)
{
std::cout << temp << " ";
}
std::cout << std::endl;
std::cout << "swap after : " << std::endl;
oneVector.swap(twoVector);
std::cout << "oneVector : ";
for(auto temp : oneVector)
{
std::cout << temp << " ";
}
std::cout << std::endl;
std::cout << "twoVector : ";
for(auto temp : twoVector)
{
std::cout << temp << " ";
}
std::cout << std::endl; return ;
}

结果是:

oneVector : 1 2 3 4 5
twoVector : 2 2 2 2 2
swap after :
oneVector : 2 2 2 2 2
twoVector : 1 2 3 4 5

vector的比较:vector模板类提供了六种比较运算符:== , != , > , < , >= , <=

如果是两个vector元素的个数相同并且元素也相同,则这两个vector对象就相同,在比较的过程中采用的是字典顺序,即:当在0~i-1的时候,两个vector都是相等的,但是在第i个元素不相等,当vectorOne[i] < vectorTwo[i]的时候,则vectorOne < vectorTwo;

#include <iostream>
#include <vector>
#include <limits>
int main()
{
std::vector<int> oneVector({,,,,});
std::vector<int> thridVector(,);
std::vector<int> twoVector(,);
if(twoVector == thridVector)
{
std::cout << "twoVector == thridVector" << std::endl;
}else
{
std::cout << "twoVector != thridVector"<< std::endl;
} if(oneVector == twoVector)
{
std::cout << "twoVector == oneVector" << std::endl;
}else
{
std::cout << "twoVector != oneVector" << std::endl;
} return ;
}

结果是:

twoVector == thridVector
twoVector != oneVector

vector详讲(一)的更多相关文章

  1. vector详讲(三)实例

    移动语义: push语句有时候会通过移动语义来提高性能 #include <iostream> #include <vector> class Element { public ...

  2. vector详讲(二)迭代器

    先看一下代码: #include <iostream> #include <vector> int main() { std::vector<double> dou ...

  3. stl——vector详解

    stl——vector详解 stl——vector是应用最广泛的一种容器,类似于array,都将数据存储于连续空间中,支持随机访问.相对于array,vector对空间应用十分方便.高效,迭代器使ve ...

  4. zTree应用实例详讲(3)

    zTree应用实例详讲(3) 上一讲中,已经讲到了重命名与删除.那么这一讲,我们来做新建文件夹. 其实新建是非常简单的,想一下我们想要的效果:点击新建,然后在一个节点下面出现一个新建的文件夹,并且与此 ...

  5. zTree应用实例详讲

    zTree应用实例详讲(1) 因为项目的需要,要创建一棵动态的文件树,此树除了实现异步获取子节点外,还要实现对树节点的增.删.改.查.移动.重命名.批量删除.批量移动. 每一个操作都要和数据库打交道. ...

  6. Java - 静态代理详讲

    Java - 静态代理详讲 作者 : Stanley 罗昊 [转载请注明出处和署名,谢谢!] 写在前面:*此章内容比较抽象,所以需要结合实际操作进行讲解*                   *需要有 ...

  7. Nginx技术进阶详讲

    Nginx技术进阶详讲 作者 : Stanley 罗昊 [转载请注明出处和署名,谢谢!] 并发数问题 讲到并发数这个概念,想必各位应该都知道是什么意思,就是同时访问一个项目,就比我们现在做的一些项目完 ...

  8. SQL优化 MySQL版 - B树索引详讲

    SQL优化 MySQL版  - -B树索引详讲 作者:Stanley 罗昊 [转载请注明出处和署名,谢谢!] 为什么要进行SQL优化呢?很显然,当我们去写sql语句时: 1会发现性能低 2.执行时间太 ...

  9. SQL优化 MySQL版 - 多表优化及细节详讲

    多表优化及细节详讲 作者 : Stanley 罗昊 [转载请注明出处和署名,谢谢!] 注:本文章需要MySQL数据库优化基础或观看前几篇文章,传送门: B树索引详讲(初识SQL优化,认识索引):htt ...

随机推荐

  1. springboot+mybatis遇到BUG:自动注入失败

    今天用springboot+mybatis写一个小demo遇到如下错误 Error starting ApplicationContext. To display the conditions rep ...

  2. bash shell学习笔记(一)—— 常用命令

    一.基本的bash shell命令 1.默认bash shell 提示符是美元符号($); 2.bash手册 使用man命令来访问存储在Linux系统上的手册页面,如: bogon:~ Mac$ ma ...

  3. POJ P2777 Count Color——线段树状态压缩

    Description Chosen Problem Solving and Program design as an optional course, you are required to sol ...

  4. Drupal网站报错:PDOException: in lock_may_be_available()

    Drupal网站报错: 原因: windows中mysql的服务停止了: 解决办法: 在服务中,启动mysql服务 启动后,刷新页面,问题完美解决

  5. ORA-16014: log 3 sequence# 540 not archived, no available destinations

    https://blog.csdn.net/zonelan/article/details/7329369

  6. npm 更新至最新版本

    有时npm版本低了,一些操作有问题,要更新成最新. 官网中:  https://www.npmjs.com/get-npm     先查看对应的 node 版本 和 npm版本 Check that ...

  7. jetty插件实现 热部署

    <plugin> <groupId>org.eclipse.jetty</groupId> <artifactId>jetty-maven-plugin ...

  8. Java 之集合框架 上(9)

    Java 中的集合框架 如果一个类中存在很多相同类型的属性. 例如:学生类 学生可以选课,因此存在很多课程类型的属性.但是每个学生选择的课程的种类和数量是不一样的. 如果将每一个课程类型的属性都列到课 ...

  9. 浏览器缓存(Web Cache/ Http Cache)

    浏览器缓存(Web Cache/ Http Cache)是前端性能优化中很重要的组成部分. 缓存策略 浏览器的缓存策略是: 1.如果本地没有缓存,则发送非条件性请求. 2.如果本地有缓存,则判断本地缓 ...

  10. maven(14)-nexus仓库基本用法

    登录 启动nexus3,访问http://localhost:8081/  点击右上角sign in登录,默认用户名:admin  密码:admin123,登陆后可以点击右上角的admin,修改默认密 ...