我一直依赖于误解,即成员函数中定义的静态变量仅限于特定的类实例。
说明我的误解:
#include <iostream>
#include <string>
struct Simple {
template<typename T>
T & Test(const T & Value) {
static T Storage = Value;
return Storage;
}
};
int main() {
Simple A;
Simple B;
std::string Foo = A.Test(std::string("Foo"));
std::string Bar = B.Test(std::string("Bar"));
std::cout << Foo << ' ' << Bar << std::endl;
}
我预期的行为会产生
的输出Foo Bar
是否有一个简单的替代方案会导致我预期的行为?
修改
具有此问题的类的缩减版本:
class SignalManager {
private:
template<typename T> struct FunctionPointer { typedef boost::function1<void, const T &> type; };
template<typename T> struct Array { typedef std::vector<typename FunctionPointer<T>::type> type; };
template<typename T>
typename Array<T>::type & GetArray() {
static typename Array<T>::type Array;
return Array;
}
public:
template<typename T, typename M>
void Broadcast(const M & Value) {
typename Array<T>::type::iterator Iterator;
for(Iterator = GetArray<T>().begin(); Iterator != GetArray<T>().end(); ++Iterator) {
(*Iterator)(Value);
}
}
template<typename T, typename F>
void Connect(const F & Function) {
GetArray<T>().push_back(Function);
}
};
答案 0 :(得分:2)
如果我理解你的困惑,另一种选择是成员变量......
template<typename T>
struct Simple {
T storage;
T & Test(const T & Value) {
storage = Value;
return Storage;
}
};
答案 1 :(得分:0)
static T Storage = Value;
尽管多次调用成员函数Test
,但上述语句只执行一次。因此,请将声明和初始化分开。
template<typename T>
T & Test(const T & Value) {
static T Storage;
Storage = Value; // Now, this is guaranteed to execute during member function calls.
return Storage;
}
这应该得到你想要的。
答案 2 :(得分:0)
你可以把它变成一个普通的非静态类变量,虽然这需要将类作为模板而不是函数...
template<typename T>
struct Simple
{
T& Test( const T& value )
{
storage = value;
return storage;
}
private:
T storage;
}