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

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值