【问题标题】:Unresolved externals using C++ lambdas [duplicate]使用 C++ lambdas 未解决的外部问题 [重复]
【发布时间】:2013-02-24 08:13:37
【问题描述】:

我收到以下代码 sn-p 未解决的外部编译错误。

acquire_gray(identity,  []{});

当我尝试使用auto时发生同样的事情

  auto acquire_callback = [](LPBITMAPINFOHEADER pbi, HANDLE hdib)
    {
            printf("Callback\n");
    };

   acquire_gray("",  acquire_callback );

但是当我传入 null 时它会编译

acquire_gray(identity,  NULL);

这是我的程序结构

驱动程序.cpp

#include "bridge.h"

void TB_AcquireImagesStart(HANDLE hNamedPipe, const TB_Message request)
{
    acquire_gray("",  []{});
}

bridge.h

template<typename T>
void acquire_gray(const string_t& identity, T& callback);

bridge.cpp

template<typename T>
void acquire_gray(const string_t& identity, T& callback)
{
   callback();
}

所以我得到的两个例外是

Error   12  error LNK1120: 1 unresolved externals

Error   11  error LNK2019: unresolved external symbol "void __cdecl acquire_gray<class <lambda_e125ff607fe0339bba6077ce9c14d586> >(class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> > const &,class <lambda_e125ff607fe0339bba6077ce9c14d586> &)" (??$acquire_gray@V<lambda_e125ff607fe0339bba6077ce9c14d586>@@@@YAXABV?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@AAV<lambda_e125ff607fe0339bba6077ce9c14d586>@@@Z) referenced in function "void __cdecl TB_AcquireImagesStart(void *,class TB_Message)" (?TB_AcquireImagesStart@@YAXPAXVTB_Message@@@Z) 

所以我的问题是我的代码出了什么问题,我该如何解决这个问题,以及为什么 auto 没有检测到我的 lambda 类型。

【问题讨论】:

  • 您不能将模板函数定义放在单独的.cpp 文件中。编译器不会看到它们。尝试将acquire_gray&lt;&gt;() 的定义放入bridge.h

标签: c++ templates lambda


【解决方案1】:

您不能将模板定义放在 .cpp 中(当然可以,但只有在该编译单元中使用它们才有意义)。编译后,仅存在模板实例。

【讨论】:

    【解决方案2】:

    这只是使用模板时的常见陷阱。您不能(或至少不应该)将模板分成头文件 (.hpp) 和源文件 (.cpp)。详情请见here

    【讨论】: