模板代码是这样的:
template <class type1>
struct DefaultInstanceCreator {
type1 * operator ()() {
return new type1;
}
};
template < class type1
, class InstanceCreator = DefaultInstanceCreator<type1> >
class objectCache
{
public:
objectCache (InstanceCreator & instCreator)
:instCreator_ (instCreator) {}
type1* Get() {
type1 * temp = instCreator_ ();
}
private:
InstanceCreator instCreator_;
};
此代码适用于像这样的对象类:
class A{
public:
A(int num){
number = num;
}
int number;
struct CreateInstance {
CreateInstance (int value) : value_ (value) {}
A * operator ()() const{
return new A(value_);
}
int value_;
};
};
objectCache< A, A::CreateInstance > intcache(A::CreateInstance(2));
A* temp = intcache.Get();
cout << temp->number <<endl;
当我尝试使用 int、string 等类型的模板时...
objectCache< int > intcache();
int* temp = intcache.Get();
*temp = 3;
cout <<temp <<endl;
我在“'.Get' must have class/struct/union”的左边得到 E, 我找不到问题出在哪里
当我变成
objectCache< int > intcache;
我得到“'objectCache':没有合适的默认构造函数可用”
使用
objectCache< int > intcache(DefaultInstanceCreator<int>());
我也忘记了“'.Get' 必须有类/结构/union ”。
最佳答案
在这里,您没有将参数传递给 intcache
构造函数:
objectCache< int > intcache();
int* temp = intcache.Get();
这会导致第一行恢复为众所周知的 "most vexing parse" C++,简而言之,你在声明 intcache
作为一个不带参数并返回 objectCache<int>
的函数.
也许你的意思是:
objectCache< int > intcache;
但您可能想传递一个工厂:
objectCache< int > intcache((DefaultInstanceCreator<int>()));
关于c++ - 如何使这个模板代码工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1170522/