检查std :: function是否为std :: plus或std :: minus

时间:2014-03-31 00:22:24

标签: c++

我有一个功能:

bool basicArithmetic(std::function<int(int, int)> func) {
}

如果truefuncstd::plus的实例,则应返回std::minus,但我不知道如何检查。我无法使用dynamic_cast,因为它不是指针。

2 个答案:

答案 0 :(得分:5)

您可以使用target()成员:

#include <functional>
#include <iostream>

int f(int, int) { return 0; }
int g(int, int) { return 0; }

void test(std::function<int(int, int)> const& arg)
{
    std::cout << "test function:\n";
    if (arg.target<std::plus<int>>()) {
        std::cout << "it is plus\n";
    }
    if (arg.target<std::minus<int>>()) {
        std::cout << "it is minus\n";
    }

    int (*const* ptr)(int, int) = arg.target<int(*)(int, int)>();
    if (ptr && *ptr == f) {
        std::cout << "it is the function f\n";
    }
    if (ptr && *ptr == g) {
        std::cout << "it is the function g\n";
    }
}

int main()
{
    test(std::function<int(int, int)>(std::plus<int>()));
    test(std::function<int(int, int)>(std::minus<int>()));
    test(std::function<int(int, int)>(f));
    test(std::function<int(int, int)>(g));
}

类型测试很简单。对特定对象的测试似乎并不那么简单:虽然对于原始问题不是必需的,但代码还显示了如何测试函数指针的特定对象。

答案 1 :(得分:2)

std::function有2个方便的成员专为此特定任务而设计:std::function::target_typestd::function::target

http://en.cppreference.com/w/cpp/utility/functional/function