เห็นได้ชัดว่ามีสองวิธีที่ชัดเจนที่สุดในการล้างstd::queue
: สลับกับวัตถุที่ว่างเปล่าและการกำหนดให้กับวัตถุที่ว่างเปล่า
ฉันอยากจะแนะนำให้ใช้การมอบหมายเพราะมันเร็วอ่านง่ายและไม่คลุมเครือ
ฉันวัดประสิทธิภาพโดยใช้โค้ดง่าย ๆ ต่อไปนี้และพบว่าการสลับในรุ่น C ++ 03 ทำงานได้ช้ากว่าการกำหนดให้วัตถุที่ว่างเปล่า 70-80% อย่างไรก็ตามใน C ++ 11 ไม่มีประสิทธิภาพแตกต่างกัน อย่างไรก็ตามฉันจะไปทำงานที่ได้รับมอบหมาย
#include <algorithm>
#include <ctime>
#include <iostream>
#include <queue>
#include <vector>
int main()
{
std::cout << "Started" << std::endl;
std::queue<int> q;
for (int i = 0; i < 10000; ++i)
{
q.push(i);
}
std::vector<std::queue<int> > queues(10000, q);
const std::clock_t begin = std::clock();
for (std::vector<int>::size_type i = 0; i < queues.size(); ++i)
{
// OK in all versions
queues[i] = std::queue<int>();
// OK since C++11
// std::queue<int>().swap(queues[i]);
// OK before C++11 but slow
// std::queue<int> empty;
// std::swap(empty, queues[i]);
}
const double elapsed = double(clock() - begin) / CLOCKS_PER_SEC;
std::cout << elapsed << std::endl;
return 0;
}
deque
สนับสนุนชัดเจน