Связыватель и шаблон Variadic заканчиваются ошибкой сегментации - PullRequest
0 голосов
/ 23 апреля 2010

Я написал следующую программу

#include <iostream>
template<typename C, typename Res, typename... Args>
class bind_class_t {
private:
  Res (C::*f)(Args...);
  C *c;
public:
  bind_class_t(Res (C::*f)(Args...), C* c) : f(f), c(c) { }
  Res operator() (Args... args) {
    return (c->*f)(args...);
  }
};

template<typename C, typename Res, typename... Args>
bind_class_t<C, Res, Args...>
bind_class(Res (C::*f)(Args...), C* c) {
  return bind_class<C, Res, Args...>(f, c);
}

class test {
public:
  int add(int x, int y) {
    return x + y;
  }
};

int main() {
  test t;
  // bind_class_t<test, int, int, int> b(&test::add, &t);
  bind_class_t<test, int, int, int> b = bind_class(&test::add, &t);
  std::cout << b(1, 2) << std::endl;
  return 0;
}

скомпилировал его с помощью gcc 4.3.3 и получил ошибку сегментации. Проведя некоторое время с gdb и этой программой, мне кажется, что адреса функции и класса перепутаны, и вызов адреса данных класса не разрешен. Более того, если я использую закомментированную строку вместо этого все работает нормально.

Может ли кто-нибудь еще воспроизвести это поведение и / или объяснить мне, что здесь происходит не так?

1 Ответ

5 голосов
/ 23 апреля 2010

Тебе нужно, наверное

return bind_class_t<C, Res, Args...>(f, c);

вместо

return bind_class<C, Res, Args...>(f, c);

В противном случае вы получите бесконечную рекурсию.

...