vector顺序容器初始化

#include "stdafx.h"
#include <vector>
#include <list>
#include <deque>
#include <iostream>
using namespace std;
class test1{
 
};

class test2
{
 test2(int i)
 {
  cout << i << endl;
 }
};

int main(int argc, char* argv[])
{
 //顺序容器vector初始化的几种方式
 //1.vector<元素类型> 变量名
 vector<string> str_vector1;

 //2.用另一个容器的副本来初始化,
 //要求容器类型必须相同,容器内元素的类型也必须相同

 vector<string> str_vector2(str_vector1);//ok
 vector<int> int_vector3(str_vector1);//error容器内包含元素的类型不同
 list<int> int_list;
 vector<int> int_vector4(int_list);//error容器类型不同
 vector<int> int_vector5;
 vector<double> double_vector(int_vector);//error容器内包含的元素类型不同
 

 //3.用一段迭代器标注的范围内的元素的副本来初始化,
 //要求容器类型可以不同,容器内元素的类型可以不同,但必须相互兼容
 //能够将复制的元素的类型转化所构建的容器元素类型
 vector<int> int_vector;
 list<int> int_list(int_vector.begin(), int_vector.end());//ok

 list<int> int_list1;
 vector<int>int_vector2(int_list1.end(), int_list1.begin());//error
 //指向list的迭代器不能比较大小(只能比较是否相等),也不能做减法,也不能加减n

 vector<double> double_vector;
 vector<int> int_vector3(double_vector.begin(), double_vector.end());//error
 //元素类型不能相互兼容

 vector<double>::iterator mid = double_vector.begin() + double_vector.size()/2;
 vector<double> double_vector1(double_vector.begin(), mid);//ok用一段元素初始化,
 //初始化区间是左闭合区[b,e)

 int arr[10];
 vector<int> int_vector3(arr, arr + sizeof(arr)/sizeof(*arr));//ok
 //可以用一段数组元素初始化容器,arr+数组长度为数组最后元素的下一位置
 //初始化时采用的是左闭合区间

 //4. C c(n, t);C c(n)如果容器的元素类型有自定义的构造函数
 //但没有提供默认的构造函数,就不能用这种方法初始化.
 
 vector<int> int_vector4(10, 5);//ok
 vector<int> int_vector5(10, 5.0);//ok,doule类型可转化为int
 vector<string> str_vector2(10, 5);//error,int能转化为string

扫描二维码关注公众号,回复: 5718800 查看本文章

 vector<test1> test1_vector(10);//ok
 vector<test2> test2_vector(10);//error没有默认构造函数
 return 0;
}

猜你喜欢

转载自blog.csdn.net/daofengdeba/article/details/12967201