diff options
author | Andrew Stitcher <astitcher@apache.org> | 2007-08-02 16:41:06 +0000 |
---|---|---|
committer | Andrew Stitcher <astitcher@apache.org> | 2007-08-02 16:41:06 +0000 |
commit | 2290d4ed915f1202bcd6cd50b1a85f27f3eb6cd2 (patch) | |
tree | 087697531f0fa4d56705f72b041b17858f8e8100 /cpp/src | |
parent | 9a6a98eac19196055e0efa24daa8742769256ec7 (diff) | |
download | qpid-python-2290d4ed915f1202bcd6cd50b1a85f27f3eb6cd2.tar.gz |
* Changed Broker queue processing to avoid unnecessary uses of boost::bind
* Changed Serializer::execute to take Tasks by reference to avoid overhead of copying
git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk/qpid@562179 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/src')
-rw-r--r-- | cpp/src/qpid/broker/BrokerQueue.cpp | 9 | ||||
-rw-r--r-- | cpp/src/qpid/broker/BrokerQueue.h | 3 | ||||
-rw-r--r-- | cpp/src/qpid/sys/Serializer.cpp | 2 | ||||
-rw-r--r-- | cpp/src/qpid/sys/Serializer.h | 2 |
4 files changed, 9 insertions, 7 deletions
diff --git a/cpp/src/qpid/broker/BrokerQueue.cpp b/cpp/src/qpid/broker/BrokerQueue.cpp index f8bffa01a3..3d4d6b83be 100644 --- a/cpp/src/qpid/broker/BrokerQueue.cpp +++ b/cpp/src/qpid/broker/BrokerQueue.cpp @@ -49,7 +49,8 @@ Queue::Queue(const string& _name, bool _autodelete, next(0), exclusive(0), persistenceId(0), - serializer(false) + serializer(false), + dispatchCallback(boost::bind(&Queue::dispatch, this)) { } @@ -79,7 +80,7 @@ void Queue::recover(Message::shared_ptr& msg){ void Queue::process(Message::shared_ptr& msg){ push(msg); - serializer.execute(boost::bind(&Queue::dispatch, this)); + serializer.execute(dispatchCallback); } @@ -89,13 +90,13 @@ void Queue::requeue(Message::shared_ptr& msg){ Mutex::ScopedLock locker(messageLock); messages.push_front(msg); } - serializer.execute(boost::bind(&Queue::dispatch, this)); + serializer.execute(dispatchCallback); } void Queue::requestDispatch(){ - serializer.execute(boost::bind(&Queue::dispatch, this)); + serializer.execute(dispatchCallback); } diff --git a/cpp/src/qpid/broker/BrokerQueue.h b/cpp/src/qpid/broker/BrokerQueue.h index f82a7dac55..4214b4b03f 100644 --- a/cpp/src/qpid/broker/BrokerQueue.h +++ b/cpp/src/qpid/broker/BrokerQueue.h @@ -75,7 +75,8 @@ namespace qpid { std::auto_ptr<QueuePolicy> policy; QueueBindings bindings; boost::shared_ptr<Exchange> alternateExchange; - qpid::sys::Serializer serializer; + qpid::sys::Serializer serializer; + qpid::sys::Serializer::Task dispatchCallback; void pop(); void push(Message::shared_ptr& msg); diff --git a/cpp/src/qpid/sys/Serializer.cpp b/cpp/src/qpid/sys/Serializer.cpp index db2b3cab6d..cdc8b91694 100644 --- a/cpp/src/qpid/sys/Serializer.cpp +++ b/cpp/src/qpid/sys/Serializer.cpp @@ -64,7 +64,7 @@ void Serializer::dispatch(Task& task) { } } -void Serializer::execute(Task task) { +void Serializer::execute(Task& task) { bool needNotify = false; { Mutex::ScopedLock l(lock); diff --git a/cpp/src/qpid/sys/Serializer.h b/cpp/src/qpid/sys/Serializer.h index eba8e48555..337686cca0 100644 --- a/cpp/src/qpid/sys/Serializer.h +++ b/cpp/src/qpid/sys/Serializer.h @@ -66,7 +66,7 @@ class Serializer : private boost::noncopyable, private Runnable * paramater to the constructor was true. Otherwise task will be * enqueued for execution by a dispatch thread. */ - void execute(Task task); + void execute(Task& task); /** Execute pending tasks sequentially in calling thread. * Drains the task queue and returns, does not block for more tasks. |