我在头文件中定义了以下函数(它所在的库旨在仅作为头文件):
typedef bool (*FieldComparer)(const std::string&, const std::string&);
inline FieldComparer
GetComparer(const std::string& query, string& separator)
{
if (query.find('=') != std::string::npos) {
separator = "=";
return [](const string& s1, const string& s2) { return s1 == s2; };
}
else if (query.find('^') != string::npos) {
separator = "^";
return [](const string& s1, const string& s2) { return boost::starts_with(s1, s2); };
}
else if (query.find('*') != string::npos) {
separator = "*";
return [](const string& s1, const string& s2) { return boost::contains(s1, s2); };
}
else if (query.find('!') != string::npos) {
separator = "!";
return [](const string& s1, const string& s2) { return s1 != s2; };
}
else
throw std::invalid_argument("Search: could not find operator in query string.");
}
template <class Description>
inline void
Search(Table<Description>& table, const std::string& query,
std::function<void(const std::string&)> callback, int begin, int limit)
{
string separator;
auto comparer = GetComparer(query, separator);
... do stuff with comparer ...
}
我正在尝试编译一个包含此文件的小型简单程序,但在链接时我得到了对所有 lambda 的 undefined reference 。当我说简单时,有一个 CPP 可以编译但无法链接。这里是第一个错误:
obj/sample.o: In function `DataModel::GetComparer(std::string const&, std::string&)::{lambda(std::string const&, std::string const&)#1}::operator bool (*)(std::string const&, std::string const&)() const':
/home/julien/workspace_dma/src/DataModel/Search.h:23: undefined reference to `DataModel::GetComparer(std::string const&, std::string&)::{lambda(std::string const&, std::string const&)#1}::_FUN(std::string const&, std::string const&)'
自从我升级到 GCC 4.7.2 后就发生了这种情况,它曾经在 GCC 4.6.2 中运行良好(Ubuntu 版本以防万一)。虽然我知道解决问题的解决方法,但我想知道我做错了什么或没有正确理解。由于lambas 在内联函数中,因此它们应该在使用该函数的任何翻译单元中定义。
-- 编辑--
还有一点值得注意:Search
和 GetComparer
示例程序中未使用函数。
Search
用于 Table<Description>
的成员函数中(我不能发布完整的类(class)):
template <class Description>
void Table<Description>::Search(const std::string& query,
std::function<void(const std::string&)> callback, int begin, int count)
{
DataModel::Search(*this, query, callback, begin, count);
}
但两者都不是从 sample.cpp 文件中调用的。该文件测试 Table
的其他功能这是无关的。如果我在成员中评论调用,代码会编译并链接。 (我需要成员函数,它是虚拟的,它是 Table
以上类型删除类的一部分)。
最佳答案
一个 bug report已向 GCC 团队提交,其中一位开发人员拥有 confirmed the issue on trunk .
同时,正如 LucDanton 在聊天中指出的那样,声明函数 static
将解决问题。
关于c++ - 在 G++ 4.7 的内联函数中定义时找不到 Lambda,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13003941/