10
int __cdecl ccall(int i)
{
    wprintf(L"ccall(%d)", i);
    return 0;
}

int __stdcall stdcall(int i)
{
    wprintf(L"stdcall(%d)", i);
    return 0;
}

int __cdecl wmain(int argc, wchar_t **argv)
{
    std::function<int(int)> fnc = ccall;
    std::function<int(int)> fnstd = stdcall;

    fnc(10); // printed well
    fnstd(100); // printed well
    return 0;
}

我担心如何将对象分配__stdcall functionstd::function对象。但是没有任何指定的调用约定,它看起来工作正常。怎么std::function知道调用约定是什么?

4

1 回答 1

8

std::function能够存储使用任何调用约定的函数指针。

§ 20.8.11.2:

函数类模板提供了泛化函数指针概念的多态包装器。包装器可以存储、复制和调用任意可调用对象(20.8.1),给定调用签名(20.8.1),允许函数成为第一类对象。

正如John Calsbeek 所 补充的:标准中没有关于调用约定的特别内容,但是编译器正在做他们的工作,函数指针包含有关约定的信息。

使用函数指针,您需要指定不寻常的调用约定:

typedef int(* c_ptr_t)(int);
typedef int(__stdcall * std_ptr_t)(int);

c_ptr_t c_ptr = ccall;
std_ptr_t std_ptr = stdcall;

// But std::function doesn't mind:
std::function<int(int)> fnc = c_ptr;
std::function<int(int)> fnstd = std_ptr;
于 2012-04-16T07:33:42.690 回答