1

当我这样做时,我得到了这个错误

运行时检查失败 #0 - ESP 的值未在函数调用中正确保存。这通常是调用使用一种调用约定声明的函数和使用另一种调用约定声明的函数指针的结果。

打电话时dutyStack[0]();。但是,如果我添加dutyStack.reserve(10);或者向量中只有一个元素,则不会出现错误。我怀疑在调整矢量大小时复制元素时发生了一些事情,但我真的不知道。

#include "stdafx.h"
#include <iostream>
#include <vector>
#include <functional>

using namespace std;
class Class1
{
public:
    void duty1(){cout<<"duty1";}
    void duty2(){cout<<"duty2";}
};

int _tmain(int argc, _TCHAR* argv[])
{
    vector<tr1::function<void()>> dutyStack;
    Class1 myclass;

    dutyStack.push_back( tr1::bind(&Class1::duty1, myclass) );
    dutyStack.push_back( tr1::bind(&Class1::duty2, myclass) );

    dutyStack[0]();
    dutyStack.erase(dutyStack.begin());
}

我在visual studio 2008,Windows 7下。

4

2 回答 2

4

我和你的环境完全相同(Win7,VS 2008)。我刚刚编译并成功执行了您的代码。

对我来说,您似乎必须重新创建您的项目,因为您可能需要更改调用 convension 或类似的东西:

配置属性 > C/C++ > 高级 > 调用约定

..所以重新创建您的项目是最简单的检查这是否是您的问题。如果不是这个,我敢打赌你的一些头文件已损坏。

于 2013-10-29T20:11:54.493 回答
2

你真的需要“stdafx.h”吗?Aka,你有为你的项目预定义的参数吗?因为以下适用于 vs2012、vs2010:

#include <iostream>
#include <vector>
#include <functional>

using namespace std;
class Class1
{
public:
    void duty1(){cout<<"duty1";}
    void duty2(){cout<<"duty2";}
};

int main()
{
    vector<tr1::function<void()>> dutyStack;
    Class1 myclass;

    dutyStack.push_back( tr1::bind(&Class1::duty1, myclass) );
    dutyStack.push_back( tr1::bind(&Class1::duty2, myclass));

    dutyStack[0]();
    dutyStack.erase(dutyStack.begin());

    system("pause");
    return 0;
}

请注意,我删除了“stdafx.h”并将“_tmain”重命名为“main”。还删除了主要声明中的 args,因为我在那里不需要它们。

我在这里读到了一些可能有共同点的东西(_stdcall as _cecl call 我相信,但我对 C++ 的了解并不远)

于 2013-10-29T13:05:33.097 回答