C++ Singleton 使用重载运算符实例化 -> 可能吗?
C++ Singleton instantiate with overloaded operator -> possible?
今天我正在用 C++ 编写单例测试用例。 单例工作正常,但我想在用户尝试访问它的成员时实例化静态对象,因此如果在我们尝试访问它的成员时未创建变量,它不会崩溃,而是会崩溃简单地生成我的单例。
这是我的 class.h:
class PDG : public EmployeRH
{
public:
static void Instantiate(std::string nom, std::string prenom);
// Current manual instantiation version of the singleton
PDG* operator->();
// This is the line I just added to overload "->" operator ... But it seems it's never called.
void SePresenter();
static PDG* _instance;
private:
PDG();
~PDG();
PDG(std::string nom, std::string prenom);
int _budget;
};
Methods.cpp
PDG* PDG::_instance=NULL;
PDG::PDG()
{
}
PDG::~PDG()
{
}
PDG::PDG(std::string a_nom, std::string a_prenom):EmployeRH(a_nom,a_prenom)
{
_budget = 100000;
}
void PDG::Instantiate(std::string a_nom, std::string a_prenom)
{
cout << "instantiation pdg" << endl;
if (_instance == NULL)
{
_instance = new PDG(a_nom,a_prenom);
}
}
PDG* PDG::operator->()
{
PDG::Instantiate("Unknown", "Unknown");
return _instance;
}
void PDG::SePresenter()
{
cout << _nom << " " << _prenom << endl;
}
main.cpp
void main()
{
PDG::_instance->SePresenter();
system("pause");
}
问题是,它直接进入 "SePresenter()" 而不是进入我的重载运算符“->”。 如果有人能提供帮助那就太好了。
谢谢,
影响
PDG::_instance
是指向 PDG 的指针,因此 ->
只是取消对指针的引用,您无法覆盖该行为。要覆盖 ->
运算符,您必须直接在 class 上调用它,而不是在指针上调用它:(*PDG::_instance)->SePresenter()
。要保留所需的语法并从取消引用空指针中删除未定义的行为,您可以将 PDG::_instance
更改为包含实例指针的结构。
#include <string>
#include <iostream>
using namespace std;
struct EmployeRH {
EmployeRH() {}
EmployeRH(std::string nom, std::string prenom) {}
std::string _nom;
std::string _prenom;
};
class PDG : public EmployeRH {
public:
static PDG* Instantiate(std::string nom, std::string prenom);
// Current manual instantiation version of the singleton
void SePresenter();
static struct Instance {
PDG* operator->()
{
return PDG::Instantiate("Unknown", "Unknown");
}
} _instance;
private:
PDG();
~PDG();
PDG(std::string nom, std::string prenom);
int _budget;
};
PDG::Instance PDG::_instance;
PDG::PDG()
{
}
PDG::~PDG()
{
}
PDG::PDG(std::string a_nom, std::string a_prenom)
: EmployeRH(a_nom, a_prenom)
{
_budget = 100000;
}
PDG* PDG::Instantiate(std::string a_nom, std::string a_prenom)
{
static PDG instance(a_nom, a_prenom);
cout << "instantiation pdg" << endl;
return &instance;
}
void PDG::SePresenter()
{
cout << _nom << " " << _prenom << endl;
}
int main()
{
PDG::_instance->SePresenter();
return 0;
}
我还更改了您的单例以使用静态函数,这使您的代码线程安全。