From ea2ee85202f7b16d7b713bc7a7dcd1fa63bc6213 Mon Sep 17 00:00:00 2001 From: lichao <lichao@aiotlink.com> Date: 星期五, 26 三月 2021 11:54:50 +0800 Subject: [PATCH] change refcount to AddRef,Release interface. --- src/msg.h | 13 ++++--------- 1 files changed, 4 insertions(+), 9 deletions(-) diff --git a/src/msg.h b/src/msg.h index 44c961f..910efa5 100644 --- a/src/msg.h +++ b/src/msg.h @@ -69,20 +69,15 @@ public: Msg(void *p=0, RefCount *c=0):ptr_(p), count_(c) {} void swap(Msg &a) { std::swap(ptr_, a.ptr_); std::swap(count_, a.count_); } - - // ~Msg() { RemoveRef(); } - // Msg(const Msg &a):ptr_(a.ptr_), count_(a.count_) { AddRef(); } - // Msg(Msg &&a):ptr_(a.ptr_), count_(a.count_) { a.ptr_ = 0; a.count_ = 0; } - // Msg & operator = (const Msg &a) { Msg(a).swap(*this); } - // Msg & operator = (Msg &&a) { Msg(std::move(a)).swap(*this); } - template <class T = void> T *get() { return static_cast<T*>(ptr_.get()); } + + // AddRef and Release works for both counted and not counted msg. int AddRef() const { return IsCounted() ? count_->Inc() : 1; } - int RemoveRef() const{ return IsCounted() ? count_->Dec() : 0; } + int Release(SharedMemory &shm) const; + int Count() const{ return IsCounted() ? count_->Get() : 1; } bool IsCounted() const { return static_cast<bool>(count_); } bool Build(SharedMemory &shm, const MQId &src_id, const void *p, const size_t size, const bool refcount); - void FreeFrom(SharedMemory &shm); }; inline void swap(Msg &m1, Msg &m2) { m1.swap(m2); } -- Gitblit v1.8.0