Передайте класс Constructor через аргумент шаблона в C ++ - PullRequest
2 голосов
/ 07 января 2012

Я знаю, что функция может проходить через template аргумент, могу ли я передать класс Constructor следующим образом.

Обновление: Причина, по которой я хочу это сделать, заключается в том, что я могу выбрать конструктор в пуле памяти и без каких-либо изменений кода в классе, который я хочу выделить (в данном случае class A)

class A
{
public:
  A(){n=0;}
  explicit A(int i){n=i;}

private:
  int n;
};

class MemoryPool
{
public:
   void* normalMalloc(size_t size);
   template<class T,class Constructor>
   T* classMalloc();
};

template<class T,class Constructor>
T* MemoryPool::classMalloc()
{
   T* p = (T*)normalMalloc(sizeof(T));
   new (p) Constructor; // choose constructor
   return p;
}

MemoryPool pool;
pool.classMalloc<A,A()>(); //get default class
pool.classMalloc<A,A(1)>();

Ответы [ 3 ]

5 голосов
/ 07 января 2012

Нельзя обойти конструкторов, но вы можете обойти фабричные функторы:

class A
{
    int n;

    A(int i) : n(i) {};

public:

    static A* makeA(int i)
    {
        return new A(i);
    }
};

template<typename T, typename Factory>
T* new_func(Factory factory)
{
    return factory();
}

#include <functional>

int main()
{
    new_func<A>(std::bind(&A::makeA, 0));
    new_func<A>(std::bind(&A::makeA, 1));
}
4 голосов
/ 07 января 2012

Все ваше предположение неверно. Вам не нужна эта функция.

template<class T>
T* new_func()
{
   return new T;
}

Вещество после new является типом, а не ссылкой на конструктор.

0 голосов
/ 08 января 2012

Так лучше я думаю

template<class T, int n>
struct Factory
{
  static T* new_func()
  {
     return new T(n);
  }
};

template<class T>
struct Factory<T,0>
{
  static T* new_func()
  {
     return new T;
  }
};

T* t = Factory<T>::new_func(); //call default constructor
T* t2 = Factory<T,2>::new_func(); //call constructor T(2)
...