假设我已经实现了一个scoped_ptr
template <typename T> class scoped_ptr {
public:
scoped_ptr() = delete;
explicit scoped_ptr(T *ptr) : _ptr(ptr){};
~scoped_ptr() {
delete _ptr;
_ptr = nullptr;
};
scoped_ptr(const scoped_ptr &p) = delete;
scoped_ptr &operator=(const scoped_ptr &p) = delete;
T *operator->() const { return _ptr; }
T &operator*() const { return *_ptr; }
T *get() const { return _ptr; }
void reset(T *p = nullptr) {
delete _ptr;
_ptr = p;
}
private:
T *_ptr;
};我想测试在指针的生命周期结束后内存是否被释放,但是我不能通过取消引用原始指针_ptr来验证这一点,因为它所指向的内存应该已经被释放了。那我该怎么测试它呢?
发布于 2019-04-15 14:31:41
使用一个带有对象计数的类怎么样?附注:您需要在reset中检查自赋值。
#include <cassert>
#include <iostream>
using namespace std;
template <typename T>
class scoped_ptr {
public:
scoped_ptr() = delete;
explicit scoped_ptr(T *ptr) : _ptr(ptr) {}
virtual ~scoped_ptr() { reset(); }
scoped_ptr(const scoped_ptr &p) = delete;
scoped_ptr &operator=(const scoped_ptr &p) = delete;
T* operator->() const { return _ptr; }
T& operator*() const { return *_ptr; }
T* get() const { return _ptr; }
void reset(T* p = nullptr) {
if (_ptr == p) {
return;
}
delete _ptr;
_ptr = p;
}
private:
T* _ptr;
};
struct ObjectCounter {
static int _object_count;
ObjectCounter() {
++_object_count;
}
virtual ~ObjectCounter() {
--_object_count;
}
};
int ObjectCounter::_object_count = 0;
int main() {
{
scoped_ptr<ObjectCounter> ptr(new ObjectCounter());
assert(ObjectCounter::_object_count == 1);
}
assert(ObjectCounter::_object_count == 0);
return 0;
}https://stackoverflow.com/questions/55676120
复制相似问题