Как вызвать функцию в C ++ из указателя функции и аргументов

Я хочу вызвать функцию по указателю на функцию с неизвестными аргументами. сохранить входные аргументы и функцию и запустить ее позже. что-то вроде 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();
}

2

Решение

Вы можете сделать то, что вы пытаетесь сделать в 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 вместо неуклюжего конструктора кортежей + прямая конструкция, но у компилятора, на котором я тестировал, этого нет)

2

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]