单例类的成员变量的生存期是多少?

What is the life time of a singleton class's member variables?

本文关键字:多少 变量 成员 单例类 生存期      更新时间:2023-10-16
class Member {
public:
    Member(int idx) {
        this->idx_ = idx;
    }
    int get_idx() {
        return idx_;
    }
    void set_idx(int idx) {
        this->idx_ = idx;
    }
    void foo();
private:
    int idx_;
};

class SingletonClass {
public:
    static SingletonClass& GetInstance() {
        static SingletonClass inst;
        return inst;
    }
    vector<Member*> get_members() {
        return this->members_;
    }
    Member* get_member(int idx) {
        return this->members_[idx];
    }
    void add_member(Member* mem) {
        this->members_.push_back(mem);
    }
private:
    SingletonClass() {}
    vector<Member*> members_;
};
void Member::foo() {
    SingletonClass inst = SingletonClass::GetInstance();
    cout << inst.get_members().size();
}

int main() {  
    SingletonClass inst = SingletonClass::GetInstance();
    inst.add_member(new Member(0));
    inst.add_member(new Member(1));
    cout << inst.get_members().size() << endl;
    Member* mem = inst.get_member(1);
    mem->foo();
    return 0;
}

输出为

2
0

似乎当我得到Member::foo()内部的SingletonClass的实例时,SingletonClass的成员变量向量members_被清除…谁能给我解释一下这是怎么发生的?我怎样才能得到预期的结果?非常感谢!

似乎当我在Member::foo()中获得SingletonClass的实例时,SingletonClass的成员变量向量members_被清除了…谁能给我解释一下这是怎么发生的?我怎样才能得到预期的结果?

您正在复制下面一行中的对象:

SingletonClass inst = SingletonClass::GetInstance();

,然后修改副本的内容。原对象保持未修改

使用:

SingletonClass& inst = SingletonClass::GetInstance();

要防止这种情况在代码的其他地方发生,请显式删除复制构造函数和复制赋值操作符。

private:
    SingletonClass() {}
    SingletonClass(SingletonClass const&) = delete;
    SingletonClass& operator=(SingletonClass const&) = delete;
    vector<Member*> members_;