1

我下面的代码给了我编译器错误,我不明白我在做什么错。有人可以帮忙吗?

基本上我要做的就是通过引用一个可以填充它的函数来传递一个 STL 映射容器。此地图容器还有一个与之关联的比较器 lambda。

#include "stdafx.h"
#include <functional>
#include <map>

using namespace std;

typedef struct _tagAddressBook
{
  string strFirstName;
  string strLastName;
  long nZipCode;
} AddressBook;

void foo(map<string, AddressBook, function<bool(const string&, const string&)>> &myAddressBook)
{
  AddressBook addressBookInstance;
  addressBookInstance.strFirstName = "Bob";
  addressBookInstance.strLastName = "Parker";
  addressBookInstance.nZipCode = 12345;

  myAddressBook.insert(std::pair<string, AddressBook>(addressBookInstance.strFirstName, addressBookInstance));
}

int _tmain(int argc, _TCHAR* argv[])
{
  auto myComparator = [] (const string &strLeft, const string &strRight) { return(strLeft.compare(strRight) <= 0 ? true : false); };
  map<string, AddressBook, decltype(myComparator)> myAddressBook(myComparator);

  foo(myAddressBook);

    return 0;
}

我在 VS2012 上收到以下编译错误

错误 1 ​​错误 C2664: 'foo' : 无法将参数 1 从 'std::map<_Kty,_Ty,_Pr>' 转换为 'std::map<_Kty,_Ty,_Pr> &' d:\my projects\mapwithlambdacomparator\ mapwithlambdacomparator\mapwithlambdacomparator.cpp 32

2   IntelliSense: a reference of type "std::map<std::string, AddressBook, std::function<bool (const std::string &, const std::string &)>, std::allocator<std::pair<const std::string, AddressBook>>> &" (not const-qualified) cannot be initialized with a value of type "std::map<std::string, AddressBook, lambda []bool (const std::string &strLeft, const std::string &strRight)->bool, std::allocator<std::pair<const std::string, AddressBook>>>" d:\My Projects\MapWithLambdaComparator\MapWithLambdaComparator\MapWithLambdaComparator.cpp  32
4

2 回答 2

1

请起一个别名:

using AdressBookMap = map<string, AddressBook, function<bool(const string&, const string&)>>;

然后使用它:

void foo(AddressBookMap& myAddressBook)
{
    // ...
}

int main(int argc, char* argv[])
{
    auto myComparator = [] (...) { ... };
    AddressBookMap myAddressBook(myComparator);

    foo(myAddressBook);

    return 0;
}

正如 Whoz 所说,lambda 不是std::function; 后者可以从前者隐式构造,但它们的类型不同。这意味着一个std::map参数化的参数与另一个参数化的参数完全无关std::map

于 2013-10-19T02:46:37.533 回答
1

Lambda 函数与std::function. 事实上,每个都是它自己的类类型。如果你想做你做的事情,你可以通过模板来做,foo然后让演绎来整理它。

template <typename Cmp>
void foo(map<std::string, AddressBook, Cmp> &myAddressBook)
{
    AddressBook addressBookInstance;
    addressBookInstance.strFirstName = "Bob";
    addressBookInstance.strLastName = "Parker";
    addressBookInstance.nZipCode = 12345;

    myAddressBook.insert(std::pair<string, AddressBook>(addressBookInstance.strFirstName, addressBookInstance));
}

这适用于我的工具链“Apple LLVM 版本 5.0 (clang-500.2.75) (基于 LLVM 3.3svn)”。我看不出它也不能与您的工具链一起使用。

于 2013-10-19T01:44:09.687 回答