1

我想StatesMachineTas中实例化所有,shared_ptr<T>然后通过 typename 访问它们。

在下面的代码中,它指的是实例化(MachineT 构造函数)和访问状态的方法(get 函数)。

是否有任何哈希图技巧或方法可以在类中存储“索引”信息,例如StateA::Index

#include <memory>
#include <vector>

template <typename... States>
class MachineT {
 public:
  MachineT() {
    states_.resize(sizeof...(States));
    for (unsigned i = 0; i < states_.size(); ++i) {
      // Instanciate states
      // states_[i].reset(new decltype(State[i])());
    }
  }
  ~MachineT() {}

  class State {
    State(int state_id) : state_id_(state_id) {}
    const size_t state_id_;
  };

  template<typename T>
  std::shared_ptr<T> get() {
    // Retrun the shared_ptr to the State
  }

  std::vector<std::shared_ptr<State>> states_;
};

struct StateA;  // Forward declaration
struct StateB;
using StateMachine = MachineT<StateA, StateB>;

class StateA : StateMachine::State {};
class StateB : StateMachine::State {};

int main(int argc, char const* argv[]) {
  StateMachine sm;

  std::shared_ptr<StateA> state_a = sm.get<StateA>();
  return 0;
}
4

1 回答 1

1

这是完全可行的。以下是在 C++14 中的操作方法:

#include <memory>
#include <tuple>

template <typename... States>
class MachineT {
 public:
  MachineT()
   : states_{
    std::make_shared<States>()...
  } {
  }
  ~MachineT() {}

  template<typename T>
  std::shared_ptr<T> get() {
      return std::get<std::shared_ptr<T>>(states_);
  }

  std::tuple<std::shared_ptr<States>...> states_;
};

struct State1 {};

int main() {

    MachineT<State1> a;
    a.get<State1>();
}

std::get可以用 C++11 工具实现的等价物

于 2020-05-22T09:06:11.457 回答