diff options
| author | Alan Conway <aconway@apache.org> | 2007-11-14 21:02:14 +0000 |
|---|---|---|
| committer | Alan Conway <aconway@apache.org> | 2007-11-14 21:02:14 +0000 |
| commit | b7c4bf711917dc5ae07fafea32d9d530d2383735 (patch) | |
| tree | d187fc43d3d0a2153d1b8c2a5ab3e55261285e9d /cpp/src/qpid/broker/MessageDelivery.cpp | |
| parent | 30e952c5e9e7084eb70633a543034fbc897a22b8 (diff) | |
| download | qpid-python-b7c4bf711917dc5ae07fafea32d9d530d2383735.tar.gz | |
Replaced shared_ptr with intrusive_ptr for qpid::Broker::Message.
Gives 9% reduction in broker heap use (perftest --count 100000.)
git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk/qpid@595056 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/src/qpid/broker/MessageDelivery.cpp')
| -rw-r--r-- | cpp/src/qpid/broker/MessageDelivery.cpp | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/cpp/src/qpid/broker/MessageDelivery.cpp b/cpp/src/qpid/broker/MessageDelivery.cpp index b29850f9e1..d7f8bceae1 100644 --- a/cpp/src/qpid/broker/MessageDelivery.cpp +++ b/cpp/src/qpid/broker/MessageDelivery.cpp @@ -39,7 +39,7 @@ namespace broker{ struct BaseToken : DeliveryToken { virtual ~BaseToken() {} - virtual AMQFrame sendMethod(Message::shared_ptr msg, DeliveryId id) = 0; + virtual AMQFrame sendMethod(intrusive_ptr<Message> msg, DeliveryId id) = 0; }; struct BasicGetToken : BaseToken @@ -50,7 +50,7 @@ struct BasicGetToken : BaseToken BasicGetToken(Queue::shared_ptr q) : queue(q) {} - AMQFrame sendMethod(Message::shared_ptr msg, DeliveryId id) + AMQFrame sendMethod(intrusive_ptr<Message> msg, DeliveryId id) { return AMQFrame(0, BasicGetOkBody( ProtocolVersion(), id.getValue(), msg->getRedelivered(), msg->getExchangeName(), @@ -66,7 +66,7 @@ struct BasicConsumeToken : BaseToken BasicConsumeToken(const string c) : consumer(c) {} - AMQFrame sendMethod(Message::shared_ptr msg, DeliveryId id) + AMQFrame sendMethod(intrusive_ptr<Message> msg, DeliveryId id) { return AMQFrame(0, BasicDeliverBody( ProtocolVersion(), consumer, id.getValue(), @@ -84,7 +84,7 @@ struct MessageDeliveryToken : BaseToken MessageDeliveryToken(const std::string& d, u_int8_t c, u_int8_t a) : destination(d), confirmMode(c), acquireMode(a) {} - AMQFrame sendMethod(Message::shared_ptr msg, DeliveryId /*id*/) + AMQFrame sendMethod(intrusive_ptr<Message> msg, DeliveryId /*id*/) { //may need to set the redelivered flag: if (msg->getRedelivered()){ |
