请教——visual studio .net 2003 VC++编译时连接器输出的错误信息不全。

徐蕴 2005-12-22 02:35:48
只有错误号没有解释。这样根本无法查错了。我的是中文企业版vs2003,英文版xp。
知道的请帮帮忙,多谢了。
输出的结果就像这样:
example1.obj : error LNK2019:
example1.obj : error LNK2019:
example1.obj : error LNK2019:
example1.obj : error LNK2019:
...全文
182 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
徐蕴 2005-12-22
  • 打赏
  • 举报
回复
呵呵,又有新发现。
当我吧控制台上的输出重定向到一个文件时,这些信息又都没了
cl test.c >aa.txt

-----------aa.txt---------

/out:test.exe
test.obj
test.obj : error LNK2019:
test.exe : fatal error LNK1120: 1

看来是中文的问题。
但是我用
echo 中文测试>result.txt
没问题

--------result.txt---------
中文测试

怎么解决呢,真是头疼
徐蕴 2005-12-22
  • 打赏
  • 举报
回复
居然命令行cl输出可以:
test.obj : error LNK2019: 无法解析的外部符号 _printfa ,该符号在函数 _main 中被
引用
test.exe : fatal error LNK1120: 1 个无法解析的外部命令
徐蕴 2005-12-22
  • 打赏
  • 举报
回复
thanks oyljerry
可能我没有把问题说清楚。目前还没有到解决2019问题这一步:)。我的问题是连接器的错误输出有问题。
我认为问题可能在连接器上,只提供了一个错误号。然后冒号后面什么都没有。所以我即便知道2019是没有定义的应用我也不知道是那个函数。待回我试试命令行。估计一样。
oyljerry 2005-12-22
  • 打赏
  • 举报
回复
无法解析的外部符号“symbol”,该符号在函数“function”中被引用

在 function 中找到了未定义的外部符号 (symbol)。若要解决此错误,请提供符号定义或移除引用它的代码。

在 Visual C++ .NET 2003 中,如果使用了 /clr 而未将 CRT 链接到可执行文件,将生成此错误。任何由编译器在未使用 /clr:initialAppDomain 时生成的对象代码都包含对 _check_commonlanguageruntime_version 函数的引用,该函数在 C 运行时库 (CRT) 中定义。如果应用程序在运行库的版本 1 上运行,该函数将会生成一个错误信息。当前编译器生成的代码与运行库的版本 1 不兼容。因此,如果在 Visual C++ .NET 2003 中编译时不使用 CRT,则应在代码中包含 _check_commonlanguageruntime_version 函数的定义。作为使用 _check_commonlanguageruntime_version 函数的替代方法,您可以与 nochkclr.obj 链接。nochkclr.obj 包含该函数的一个空版本,当您在运行库的版本 1 上运行应用程序时,nochkclr.obj 不生成错误信息。若要使用当前编译器版本生成应用程序以在运行库的以前版本上运行,应使用 /clr:InitialAppDomain。

若要生成一个纯 MSIL 可执行文件(不与 CRT 链接),则必须在项目中定义该函数,而不能使用 nochkclr.obj(.obj 是本机代码)。有关可验证代码的更多信息,请参见产生可验证的 C++ 托管扩展组件。有关从托管 C++ 项目创建纯 MSIL 输出文件的更多信息,请参见将 C++ 托管扩展项目从混合模式转换成纯 IL。

本主题的其余部分讨论 LNK2019 的其他原因。

请看下面的示例:

extern int i;
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
struct X {
static int si;
};

// int X::si = 0; // uncomment this line to resolve

void 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
void f(T)
{
}

template
struct S
{
friend void f(T);
// Try the folowing line instead:
// friend void f(T);
};

int main()
{
S s;
f(1); // unresolved external
}
/VERBOSE 链接器选项帮助您查看链接器引用的文件。DUMPBIN 实用工具的 /EXPORT 和 /SYMBOLS 选项还可以帮助您查看 dll 和对象/库文件中定义的符号。
oyljerry 2005-12-22
  • 打赏
  • 举报
回复
try rebuild all
徐蕴 2005-12-22
  • 打赏
  • 举报
回复
up

7,540

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 VC.NET
社区管理员
  • VC.NET社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧