Make swapping the incoming queue with the work queue constant time.
This is an alternative to the fix proposed here:
http://codereview.chromium.org/172101
Credit goes to Dean McNamee for discovering this performance issue!
R=deanm
BUG=20204
TEST=none
Review URL: http://codereview.chromium.org/190006
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@25223 0039d316-1c4b-4281-b951-d872f2087c98
CrOS-Libchrome-Original-Commit: b2f0ea1a109f6406d6633f51adb4621090b9032d
diff --git a/base/message_loop.cc b/base/message_loop.cc
index 5464670..bf5256a 100644
--- a/base/message_loop.cc
+++ b/base/message_loop.cc
@@ -354,7 +354,7 @@
AutoLock lock(incoming_queue_lock_);
if (incoming_queue_.empty())
return;
- std::swap(incoming_queue_, work_queue_);
+ incoming_queue_.Swap(&work_queue_); // Constant time
DCHECK(incoming_queue_.empty());
}
}
diff --git a/base/message_loop.h b/base/message_loop.h
index 395ce6e..d2fcc12 100644
--- a/base/message_loop.h
+++ b/base/message_loop.h
@@ -281,7 +281,13 @@
bool operator<(const PendingTask& other) const;
};
- typedef std::queue<PendingTask> TaskQueue;
+ class TaskQueue : public std::queue<PendingTask> {
+ public:
+ void Swap(TaskQueue* queue) {
+ c.swap(queue->c); // Calls std::deque::swap
+ }
+ };
+
typedef std::priority_queue<PendingTask> DelayedTaskQueue;
#if defined(OS_WIN)