我有一个像这样的对象缓存类:
#include "boost/thread/mutex.hpp"
#include "boost/unordered_map.hpp"
template <typename type1, typename type2>
class objectCache
{
public:
objectCache()
{
IDCounter = 0;
}
~objectCache()
{
for ( it=free_objects.begin() ; it != free_objects.end(); it++ )
delete (*it).second;
for ( it=busy_objects.begin() ; it != busy_objects.end(); it++ )
delete (*it).second;
}
type1* objectCache::Get()
{
boost::mutex::scoped_lock(io_mutex);
if(free_objects.size() > 0)
{
it = free_objects.begin();
type1 *temp = (*it).second;
busy_objects[(*it).first] = temp;
free_objects.erase(free_objects.begin());
return temp;
}
type1 * temp = new type2;
++IDCounter;
busy_objects[IDCounter] = temp;
return temp;
}
void objectCache::Pushback(type1)
{
boost::mutex::scoped_lock(io_mutex);
free_objects[ID] = socket;
it = busy_objects.find(ID);
busy_objects.erase(it);
}
protected:
private:
boost::mutex io_mutex;
long long IDCounter;
boost::unordered_map<long long, type1*> free_objects;
boost::unordered_map<long long, type1*> busy_objects;
typename boost::unordered_map<long long, type1*>::iterator it;
};
class A{
public:
A(int num){
number = num;
}
int number;
};
int main(int argc, char* argv[])
{
objectCache<a, a(1)> intcache;
A* temp = intcache.Get();
cout <<temp->number <<endl;
system("pause");
return 0;
}
我知道“typename type2”是不必要的,但是我需要一种方法来将一个类对象传递给模板,该类对象具有带类A的参数的构造函数。 或者他们是另一种方式吗?请帮忙。
答案 0 :(得分:0)
您可以在方法上使用模板参数:
template <typename type2>
type1* objectCache::Get()
答案 1 :(得分:0)
你想要这样的东西吗?
template <typename type1>
class objectCache
{
// ...
template<typename type2>
type1* Get(type2 value)
{
boost::mutex::scoped_lock(io_mutex);
if(free_objects.size() > 0)
{
it = free_objects.begin();
type1 *temp = (*it).second;
busy_objects[(*it).first] = temp;
free_objects.erase(free_objects.begin());
return temp;
}
type1 * temp = new type1(value);
++IDCounter;
busy_objects[IDCounter] = temp;
return temp;
}
// ...
};
int main(int argc, char* argv[])
{
objectCache<A> intcache;
A* temp = intcache.Get(1);
cout << temp->number << endl;
system("pause");
return 0;
}
答案 2 :(得分:0)
传递一个为您创建实例的对象,而不是传递显式值:
template <typename type1>
struct DefaultInstanceCreator {
type1 * operator ()() const {
return new type1;
}
};
template < typename type1
, typename InstanceCreator = DefaultInstanceCreator<type1> >
class objectCache {
public:
objectCache (InstanceCreator const & instCreator)
: instCreator_ (instCreator) {
}
type1* Get() {
type1 * temp = instCreator_ ();
}
private:
InstanceCreator instCreator_;
};
然后你的对象可以拥有它自己的特定创建者:
class A {
public:
A(int num){
number = num;
}
int number;
public:
struct CreateInstance {
CreateInstance (int value)
: value_ (value) {
}
A * operator ()() const {
return new A(value_);
}
int value_;
};
};
int main(int argc, char* argv[]) {
objectCache<A, A::CreateInstance> intcache ( A::CreateInstance (1) );
A* temp = intcache.Get();
return 0;
}
这种方法的优点是,您可以将缓存用于与其构造函数具有不同数量参数的对象。
答案 3 :(得分:0)
int main(int argc, char* argv[])
{
objectCache<a, a(1)> intcache;
...
}
错了。您应该指出objectCache类使用的类型。 它应该像
objectCache<A, A> intcache;
在实例化A的对象时,在objectCache类中,您将不得不这样做 将参数传递给其构造函数。
例如:
...
type1 * temp = new type1(1);
...