Я хочу вызвать функцию по указателю на функцию с неизвестными аргументами. сохранить входные аргументы и функцию и запустить ее позже. что-то вроде call_user_func_array
в php
например:
// example function definition
void foo(int arg1, const char *arg2,const char *arg3){
//some other code
}
void bar(int arg1, int arg2){
//some other code
}
// function definition
void store_function_call(int param,void *function,... args){
// store param , function, and other arguments
// in php save to global variable for use later
}
void call_later(){
// execute stored param, function, arguments
// in PHP use call_user_func_array
}
// use:
int main(){
store_function_call(10,bar,4,5);
// store_function_call(5,foo,5,"yyy","sss");
call_later();
}
Вы можете сделать то, что вы пытаетесь сделать в C ++ 11 с небольшим количеством метапрограммирования шаблона:
#include <tuple>
#include <iostream>
template<int ...> struct seq {};
template<int N, int ...S> struct gens : gens<N-1, N-1, S...> {};
template<int ...S> struct gens<0, S...>{ typedef seq<S...> type; };
double foo(int x, float y, double z) {
return x + y + z;
}
template <typename R, typename ...Args>
struct save_it_for_later {
std::tuple<Args...> params;
R (*func)(Args...);
R call_later() {
return callFunc(typename gens<sizeof...(Args)>::type());
}
template<int ...S>
R callFunc(seq<S...>) {
return func(std::get<S>(params) ...);
}
};
template <typename R, typename ...Args>
save_it_for_later<R, Args...> store_function_call(R (*func)(Args...), Args&& ...args) {
return save_it_for_later<R, Args...>{std::tuple<Args...>(std::forward<Args>(args)...), func};
}
int main() {
auto saved = store_function_call(foo,1,1.f,1.);
std::cout << saved.call_later() << "\n";
}
Этот ответ изменен в соответствии с вашим сценарием из этот ответ на аналогичный вопрос, который я задал. Я добавил вывод типа возврата и помощник для вывода типов в качестве вашего store_function_call
,
(Я бы использовал std::forward_as_tuple
вместо неуклюжего конструктора кортежей + прямая конструкция, но у компилятора, на котором я тестировал, этого нет)
Других решений пока нет …