Abrufen von Funktionsargumenttypen in einer variadischen Vorlagenklasse
Die angegebene Funktorklasse Foo bietet eine Möglichkeit, Funktionen mit beliebigen Argumentlisten aufzurufen . Allerdings stellt die Bestimmung der Argumenttypen innerhalb des Konstruktors eine Herausforderung dar.
Um dieses Problem zu lösen, können Sie die Klasse „function_traits“ wie folgt verwenden:
<code class="cpp">template<typename T> struct function_traits; template<typename R, typename ...Args> struct function_traits<std::function<R(Args...)>> { static const size_t nargs = sizeof...(Args); typedef R result_type; template <size_t i> struct arg { typedef typename std::tuple_element<i, std::tuple<Args...>>::type type; }; };</code>
Innerhalb der Klasse „Foo“ können Sie „function_traits“ verwenden So erhalten Sie Informationen zum Argumenttyp:
<code class="cpp">class Foo { std::function<void(ARGS...)> m_f; public: using result_type = typename function_traits<decltype(m_f)>::result_type; using arg0_type = typename function_traits<decltype(m_f)>::arg<0>::type; // ... Additional argument types as needed };</code>
Dieser Ansatz ermöglicht es Ihnen, das Typsystem zu nutzen, um auf generische und typsichere Weise auf die Funktionsargumenttypen zuzugreifen und diese zu bearbeiten.
Das obige ist der detaillierte Inhalt vonWie rufe ich Funktionsargumenttypen in einer Variadic-Vorlagenklasse ab?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!