std::list里面的push_back和resize效率问题

2024年8月6日:

向list里面循环添加数据,两种写法

cpp 复制代码
for(;;){
  myList.resize(myList.size()+1);
  MyObject &obj= *myList.rbegin();
  obj.a= itervalue;
}

第二种写法是push_back:

cpp 复制代码
for(;;){
  MyObject obj;
  obj.a= itervalue;
  myList.push_back(obj);
}

用第一种用法,是避免了push_back的拷贝构造函数,用的缺省构造函数,对于COPY构造函数效率毕竟低的场景,也许有效。但是大部分时间应该没有啥用。

效率上,找了一个评测网站:

Quick C++ Benchmarks

代码:

cpp 复制代码
#include <vector>
#include <list>

constexpr size_t loopCount = 1000;

struct BigObject{
    double LongDouble[10000];
};

static void VectorPushBack(benchmark::State& state) {
  for (auto _ : state) {
    std::vector<BigObject> vec;
    for (int i = 0; i < loopCount; i++) {
      BigObject bo;
      vec.push_back(bo);
    }
    benchmark::DoNotOptimize(vec);
  }
}
BENCHMARK(VectorPushBack);

static void VectorEmplaceBack(benchmark::State& state) {
  for (auto _ : state) {
    std::vector<BigObject> vec;
    for (int i = 0; i < loopCount; i++) {
      vec.emplace_back();
    }
    benchmark::DoNotOptimize(vec);
  }
}
BENCHMARK(VectorEmplaceBack);

static void ListPushBack(benchmark::State& state) {
  for (auto _ : state) {
    std::list<BigObject> list;
    for (int i = 0; i < loopCount; i++) {
      BigObject bo;
      list.push_back(bo);
    }
    benchmark::DoNotOptimize(list);
  }
}
BENCHMARK(ListPushBack);

static void ListEmplaceBack(benchmark::State& state) {
  for (auto _ : state) {
    std::list<BigObject> list;
    for (int i = 0; i < loopCount; i++) {
      list.emplace_back();
    }
    benchmark::DoNotOptimize(list);
  }
}
BENCHMARK(ListEmplaceBack);
static void ListResize(benchmark::State& state) {
  for (auto _ : state) {
    std::list<BigObject> list;
    for (int i = 0; i < loopCount; i++) {
      BigObject bo;
      //list.push_back(bo);
      list.resize(list.size()+1);
      BigObject &obj = *list.rbegin();
      obj=bo;
    }
    benchmark::DoNotOptimize(list);
  }
}
BENCHMARK(ListResize);

结果:push_back效率最高,高的原因不详

参考:

https://www.reddit.com/r/cpp_questions/comments/15uekey/push_back_big_object_into_stdvector_by_creating/?rdt=60610

相关推荐
hh随便起个名6 小时前
力扣二叉树的三种遍历
javascript·数据结构·算法·leetcode
xie_pin_an8 小时前
深入浅出 C 语言数据结构:从线性表到二叉树的实战指南
c语言·数据结构·图论
tang&8 小时前
滑动窗口:双指针的优雅舞步,征服连续区间问题的利器
数据结构·算法·哈希算法·滑动窗口
Nandeska9 小时前
2、数据库的索引与底层数据结构
数据结构·数据库
又是忙碌的一天11 小时前
二叉树的构建与增删改查(2) 删除节点
数据结构
Code Slacker11 小时前
LeetCode Hot100 —— 滑动窗口(面试纯背版)(四)
数据结构·c++·算法·leetcode
F_D_Z12 小时前
最长连续序列(Longest Consecutive Sequence)
数据结构·算法·leetcode
WolfGang00732112 小时前
代码随想录算法训练营Day50 | 拓扑排序、dijkstra(朴素版)
数据结构·算法
一直都在57213 小时前
数据结构入门:二叉排序树的删除算法
数据结构·算法
hweiyu0013 小时前
排序算法简介及分类
数据结构