C++如何将一个vector内容赋值给另一个vector,及swap与assign区别

 更新时间:2023年08月09日 11:07:26   作者:SunkingYang  
在本文中,我们将主要介绍5种将一个vector内容赋值给另一个vector的方式,顺便讨论下swap与assign的区别,如有错误或未考虑完全的地方,望不吝赐教

赋值

方式一、申明时赋值

vector<int> v2;
v2.push_back(0);
v2.push_back(1);
vector<int> v1(v2); //声明

方式二、使用assign赋值

vector<int> v2;
v2.push_back(0);
v2.push_back(1);
vector<int> v1; //声明v1
v1.assign(v2.begin(), v2.end());//将v2赋值给v1

方式三、使用swap赋值

vector<int> v2;
v2.push_back(0);
v2.push_back(1);
vector<int> v1();
v1.swap(v2); //将v2赋值给v1

方式四、迭代器遍历赋值

使用迭代器和循环语句赋值的方法,其方法运行效率较差:

vector<int> v2;
v2.push_back(0);
v2.push_back(1);
vector<int> v1;
vector<int>::iterator it;//声明迭代器
for(it = v2.begin(); it!=v2.end(); ++it)//遍历v2,赋值给v1
{
	v1.push_back(it);
}

方式五、直接用等号(=)赋值

vector<int> v2;
v2.push_back(0);
v2.push_back(1);
vector<int> v1;
v1 = v2;

但这种方式需要注意:

如果在参数赋值,请注意使用指针或者引用,否则导致赋值失败,该内容不属于本文讨论范围

但举个例:

//引用方式传参
int testFun1(vector<int> &v1)
{
	vector<int> v2;
	v2.push_back(0);
	v2.push_back(1);
	v1 = v2;
}
//指针方式传参
int testFun2(vector<int> *v1)
{
	vector<int> v2;
	v2.push_back(0);
	v2.push_back(1);
	v1 = &v2;
}
//全局或者局部变量方式
vector<int> v2;
int testFun2(vector<int> v1)
{
	v2.push_back(0);
	v2.push_back(1);
	v1 = v2;
}
int testFun2()
{
	//方式一
	vector<int> v1;
	testFun1(&v1);
	//方式二
	vector<int> *v2;
	testFun1(v2);
	//方式三
	vector<int> v3;
	testFun1(v3);
}

swap与assign的区别

我们此处主要讨论它们两的用作用和效率。

  • 作用

swap和assign都可以用在将一个vector的内容全部复制给另外一个vector,

区别是swap会改变源vector,而assign会清空目的vector后再将源vector的值全部插入到目的vector中。

  • 效率

swap只是交换vector的头指针,时间复杂度是常数;

而assigin时间复杂度则是线性。

测试代码

#include <vector>
#include "DebugUtility.h"
#include <iostream>
#include <algorithm>
#include <string>
using namespace std;
void print(int x)
{
    cout << x << endl;
}
void Swap(vector<string>& source, vector<string>& dest)
{
    DebugUtility temp;
    dest.swap(source);
}
void Assign(vector<string>& source, vector<string>& dest)
{
    DebugUtility temp; 
    dest.assign(source.begin(), source.end());
}
int main(int argc, const char *argv[])
{
    vector<string> source(900000, "90");
    vector<string> destination(1, "abc");
    Swap(source, destination);
    //source.clear();
    //for_each(destination.begin(), destination.end(), print);
    //Assign(source, destination);
    //source.clear();
    //for_each(destination.begin(), destination.end(), print);
    return 0;
}

测试结果

Total time elapsed : 1 us
900000

Total time elapsed : 12391 us
900000

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • C语言中字符的输入输出以及计算字符个数的方法详解

    C语言中字符的输入输出以及计算字符个数的方法详解

    这篇文章主要介绍了C语言中字符的输入输出以及计算字符个数的方法,是C语言入门学习中的基础知识,需要的朋友可以参考下
    2015-11-11
  • C++实现高并发异步定时器

    C++实现高并发异步定时器

    这篇文章主要为大家详细介绍了如何利用C++实现高并发异步定时器,文中的示例代码讲解详细,具有一定的学习价值,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-11-11
  • C++和C的混合编译的项目实践

    C++和C的混合编译的项目实践

    本文主要介绍了C++和C的混合编译的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-06-06
  • 使用VS Code进行Qt开发的实现

    使用VS Code进行Qt开发的实现

    这篇文章主要介绍了使用VS Code进行Qt开发的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-10-10
  • C语言开发之归并排序详解及实例

    C语言开发之归并排序详解及实例

    这篇文章主要介绍了 C语言开发之归并排序详解及实例的相关资料,需要的朋友可以参考下
    2017-03-03
  • C++模拟实现string的示例代码

    C++模拟实现string的示例代码

    这篇文章主要为大家详细介绍了C++模拟实现string的相关资料,文中的示例代码讲解详细,对我们学习C++有一定的帮助,需要的可以参考一下
    2022-11-11
  • 详解C/C++高精度(加减乘除)算法中的压位优化

    详解C/C++高精度(加减乘除)算法中的压位优化

    在高精度计算中数组的每个元素存储一位10进制的数字,这样的存储方式并不是最优的,32位的整型其实至少可以存储9位高精度数字,数组元素存储更多的位数就是压位优化。本文将展示压位优化的原理以及压9位的实现和性能对比,需要的可以参考一下
    2023-01-01
  • C++11系列学习之列表初始化

    C++11系列学习之列表初始化

    这篇文章主要介绍了C++11系列学习之列表初始化,标准初始化方式太过繁杂,限制偏多,因此在新标准中统一了初始化方,为了让初始化具有确定的效果,于是提出了列表初始化概念,下文我们就一起来学习该详细内容介绍吧
    2022-04-04
  • C语言结构体内存对齐详解

    C语言结构体内存对齐详解

    大家好,本篇文章主要讲的是C语言结构体内存对齐详解,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下
    2022-01-01
  • C++实现通讯录功能

    C++实现通讯录功能

    这篇文章主要为大家详细介绍了C++实现通讯录功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-06-06

最新评论