我写了个函数返回数据库字段值,返回类型是不确定的,可能是数字或字符
_variant_t CVariantDlg::vartest(int i)
{
_variant_t rvalue;
switch (i)
{
case 1:
rvalue=(float)199;
break;
case 2:
rvalue=(double)3.1415926;
break;
case 3:
rvalue=(WCHAR *)L"test var";
break;
}
return rvalue;
}
_variant_t CVariantDlg::vartest(int i)
{
_variant_t rvalue;
switch (i)
{
case 1:
rvalue=(float)199;
break;
case 2:
rvalue=(double)3.1415926;
break;
case 3:
rvalue=(WCHAR *)L"test var";
break;
}
return rvalue;
}
{
_variant_t rvalue;
switch (i)
{
case 1:
//¾ÙÀý
rvalue.vt = VT_R4;
rvalue.dblVal = (float)199; break;
case 2:
rvalue.vt = VT_R8;
rvalue.dblVal = (double)3.1415926; break;
case 3:
rvalue=(WCHAR *)L"test var";
break;
}
return rvalue;
}
_t@@H@Z)
头文件已经引用了#include "comdef.h"
#include "comutil.h"
error LNK2019: unresolved external symbol "void __cdecl _com_issue_error(long)" (?_com_issue_error@@YAXJ@Z) referenced in function "public: class _variant_t __thiscall CVariantDlg::vartest(int,int &)" (?vartest@CVariantDlg@@QAE?AV_v
ariant_t@@HAAH@Z)
#include "comutil.h"放入stdafx.h试试
extern void g();
void f()
{
i++;
g();
}
int main()
{
}
如果在生成中包含的某个文件中没有定义 i 和 g,链接器将生成 LNK2019。可以添加这些定义,方法是将包含这些定义的源代码文件包括为编译的一部分。或者可以将包含这些定义的 .obj 或 .lib 文件传递给链接器。对于从早期版本升级到当前版本的 C++ 项目,如果定义了 __UNICODE 并且入口点为 WinMain,需要将入口点函数的名称更改为 _tWinMain 或 _tmain。导致 LNK2019 的常见问题有: 符号声明包含拼写错误,以致于符号声明与符号定义不同。
使用了一个函数,但其参数的类型或数量与函数定义不匹配。
函数声明使用和函数定义使用中的调用约定(__cdecl、__stdcall 或 __fastcall)不同。
符号定义在编译为 C 程序的文件中,而符号是在 C++ 文件中不带 extern "C" 修饰符声明的。在此情况下,请修改声明,例如不是使用:
extern int i;
extern void g();
而使用: extern "C" int i;
extern "C" void g();
同样,如果在将由 C 程序使用的 C++ 文件中定义符号,请在定义中使用 extern "C"。 符号定义为静态,但稍后在文件外部被引用。
没有定义静态类成员。例如,应单独定义下面类声明中的成员变量 si:
#include <stdio.h>
struct X {
static int si;
};// int X::si = 0; // uncomment this line to resolvevoid main()
{
X *px = new X[2];
printf("\n%d",px[0].si); // LNK2019
}
也可能由于为 Visual Studio .NET 2003 进行的一致性工作生成此错误:模板友元和专用化。在 Visual Studio .NET 2003 中,必须定义声明新的非模板函数的友元声明。要使代码在 Visual C++ 的 Visual Studio .NET 2003 和 Visual Studio .NET 版本中均有效,请显式指定友元函数的模板参数列表。// LNK2019.cpp
// LNK2019 expected
template<class T>
void f(T)
{
}template<class T>
struct S
{
friend void f(T);
// Try the folowing line instead:
// friend void f<T>(T);
};int main()
{
S<int> s;
f(1); // unresolved external
}
/VERBOSE 链接器选项帮助您查看链接器引用的文件。DUMPBIN 实用工具的 /EXPORT 和 /SYMBOLS 选项还可以帮助您查看 dll 和对象/库文件中定义的符号。