1、利用数组对vector进行初始化方法
当然有许多方法,这里就讲一种。原因简单,其他方式请参见这个博文:http://www.cplusplus.me/1112.html
int a[] = {-1, 1, 1, 1, -1}; vector<int> n(a, a+sizeof(a)/sizeof(int));
这里面涉及指针的知识与sizeof的用法。
指针偏移 其实移动的是某一个类型大小的值。
特性3:sizeof能求得静态分配内存的数组的长度!
Int a[10];int n = sizeof(a);
假设sizeof(int)等于4,则n= 10*4=40;
特别要注意:charch[]=”abc”;sizeof(ch);
结果为4,注意字符串数组末尾有’\0’!通常我们可以利用sizeof来计算数组中包含的元素个数,其做法是:int n = sizeof(a)/sizeof(a[0]);
非常需要注意的是对函数的形参数组使用sizeof的情况。举例来说,假设有如下的函数:
void fun(int array[10])
{
int n = sizeof(array);
}
你会觉得在fun内,n的值为多少呢?如果你回答40的话,那么我很遗憾的告诉你,你又错了。这里n等于4,事实上,不管形参是int的型数组,还是float型数组,或者其他任何用户自定义类型的数组,也不管数组包含多少个元素,这里的n都是4!为什么呢?原因是在函数参数传递时,数组被转化成指针了,或许你要问为什么要转化成指针,原因可以在很多书上找到,我简单说一下:假如直接传递整个数组的话,那么必然涉及到数组元素的拷贝(实参到形参的拷贝),当数组非常大时,这会导致函数执行效率极低!而只传递数组的地址(即指针)那么只需要拷贝4byte。
// Vector_Learning.cpp : 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include <vector>
#include <iostream>
using namespace std;
int _tmain(int argc, _TCHAR* argv[])
{
int int_array[] = {1, 2, 3, 4};
for(int i = 0; i < 4; i++) {
cout << int_array[i];
}
cout << endl;
std::vector<int> vec_int(int_array, int_array+4);
for(vector<int>::iterator ite_vec_int = vec_int.begin();
ite_vec_int != vec_int.end();
ite_vec_int++){
cout << *ite_vec_int;
(*ite_vec_int)++;
}
cout << endl;
for(vector<int>::iterator ite_vec_int = vec_int.begin();
ite_vec_int != vec_int.end();
ite_vec_int++){
cout << *ite_vec_int;
}
cout << endl;
for(int i = 0; i < 4; i++) {
cout << int_array[i];
}
return 0;
}
1234 1234 2345 1234 请按任意键继续. . .