0

0

C++ 容器库中容器拷贝和移动的性能比较

王林

王林

发布时间:2024-05-28 10:03:02

|

1105人浏览过

|

来源于php中文网

原创

容器移动比拷贝快,因为移动避免了元素拷贝,直接将元素所有权转移。对于大型容器,移动容器可显著提高性能。

C++ 容器库中容器拷贝和移动的性能比较

C++ 容器库中容器拷贝和移动的性能比较

在 C++ 中,容器拷贝和移动是两种用于复制容器内容的操作。理解这两者的区别和性能差异对于优化代码至关重要。

拷贝容器

立即学习C++免费学习笔记(深入)”;

容器拷贝会创建容器的新副本,其中包含原始容器中所有元素的副本。这种操作包括对每个元素执行深拷贝,这可能是一个耗时的过程。

std::vector vec1 = {1, 2, 3};
std::vector vec2(vec1); // 拷贝 vec1

移动容器

容器移动会将原始容器的内容"移动"到新容器中,而不是创建副本。这是一种更轻量级的操作,因为它直接将元素所有权从一个容器转移到另一个容器,而不执行任何拷贝。

妙话AI
妙话AI

免费生成在抖音、小红书、朋友圈能火的图片

下载
std::vector vec1 = {1, 2, 3};
std::vector vec2 = std::move(vec1); // 移动 vec1

性能比较

容器拷贝的性能开销比移动高,因为后者避免了元素拷贝步骤。对于大型容器,移动容器可以显著提高性能。

以下代码展示了不同容器类型在不同元素大小下的拷贝和移动时间比较:

#include 
#include 
#include 

int main()
{
    const int iterations = 100000;

    for (int size = 10000; size <= 100000; size += 10000)
    {
        // 创建容器
        std::vector vec(size);
        std::list list(size);

        // 记录拷贝时间
        std::clock_t start = std::clock();
        for (int i = 0; i < iterations; i++)
        {
            std::vector vecCopy(vec);
        }
        std::clock_t end = std::clock();
        std::cout << "Vector copy: " << (double)(end - start) / CLOCKS_PER_SEC << "s" << std::endl;

        start = std::clock();
        for (int i = 0; i < iterations; i++)
        {
            std::list listCopy(list);
        }
        end = std::clock();
        std::cout << "List copy: " << (double)(end - start) / CLOCKS_PER_SEC << "s" << std::endl;

        // 记录移动时间
        start = std::clock();
        for (int i = 0; i < iterations; i++)
        {
            std::vector vecMove(std::move(vec));
        }
        end = std::clock();
        std::cout << "Vector move: " << (double)(end - start) / CLOCKS_PER_SEC << "s" << std::endl;

        start = std::clock();
        for (int i = 0; i < iterations; i++)
        {
            std::list listMove(std::move(list));
        }
        end = std::clock();
        std::cout << "List move: " << (double)(end - start) / CLOCKS_PER_SEC << "s" << std::endl << std::endl;
    }

    return 0;
}

输出 (示例,实际结果可能会因系统而异):

Vector copy: 0.052s
List copy: 0.009s

Vector move: 0.014s
List move: 0.003s

...

Vector copy: 0.542s
List copy: 0.058s

Vector move: 0.082s
List move: 0.013s

正如输出所示,对于所有元素大小,移动容器都比拷贝容器快得多。

结论

对于大型容器,在不需要原始容器时,移动容器是拷贝容器的首选。通过理解容器拷贝和移动之间的差异,您可以做出明智的决策并优化代码的性能。

相关文章

数码产品性能查询
数码产品性能查询

该软件包括了市面上所有手机CPU,手机跑分情况,电脑CPU,电脑产品信息等等,方便需要大家查阅数码产品最新情况,了解产品特性,能够进行对比选择最具性价比的商品。

下载

相关标签:

c++

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

97

2026.01.09

c++框架学习教程汇总
c++框架学习教程汇总

本专题整合了c++框架学习教程汇总,阅读专题下面的文章了解更多详细内容。

50

2026.01.09

学python好用的网站推荐
学python好用的网站推荐

本专题整合了python学习教程汇总,阅读专题下面的文章了解更多详细内容。

139

2026.01.09

学python网站汇总
学python网站汇总

本专题整合了学python网站汇总,阅读专题下面的文章了解更多详细内容。

12

2026.01.09

python学习网站
python学习网站

本专题整合了python学习相关推荐汇总,阅读专题下面的文章了解更多详细内容。

19

2026.01.09

俄罗斯手机浏览器地址汇总
俄罗斯手机浏览器地址汇总

汇总俄罗斯Yandex手机浏览器官方网址入口,涵盖国际版与俄语版,适配移动端访问,一键直达搜索、地图、新闻等核心服务。

81

2026.01.09

漫蛙稳定版地址大全
漫蛙稳定版地址大全

漫蛙稳定版地址大全汇总最新可用入口,包含漫蛙manwa漫画防走失官网链接,确保用户随时畅读海量正版漫画资源,建议收藏备用,避免因域名变动无法访问。

431

2026.01.09

php学习网站大全
php学习网站大全

精选多个优质PHP入门学习网站,涵盖教程、实战与文档,适合零基础到进阶开发者,助你高效掌握PHP编程。

49

2026.01.09

php网站搭建教程大全
php网站搭建教程大全

本合集专为零基础用户打造,涵盖PHP网站搭建全流程,从环境配置到实战开发,免费、易懂、系统化,助你快速入门建站!

13

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Node.js 教程
Node.js 教程

共57课时 | 8.4万人学习

ASP 教程
ASP 教程

共34课时 | 3.4万人学习

PHP课程
PHP课程

共137课时 | 8.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号