LNK2001⽆法解析的外部符号
今天写了⼀个⼩程序,然后碰到了“Error LNK2001 ⽆法解析的外部符号”这个问题,⼀直解决不了,后来上⽹搜了下,发现这⾥⾯的关于这类错误的内容归纳⽐较齐全,就摘下来作为参考了。
VC++时经常会遇到链接错误LNK2001,该错误⾮常讨厌,因为对于编程者来说,最好改的错误莫过于编译错误,⽽⼀般说来发⽣连接错误时,编译都已通过。产⽣连接错误的原因⾮常多,尤其LNK2001错误,常常使⼈不明其所以然。如果不深⼊地学习和理解VC++,要想改正连接错误LNK2001⾮常困难。初学者在学习VC++的过程中,遇到的LNK2001错误的错误消息主要为:  unresolved  external  symbol  “symbol”(不确定的外部“符号”)。如果连接程序不能在所有的库和⽬标⽂件内到所引⽤的函数、变量或标签,将产⽣此错误消息。⼀般来说,发⽣错误的原因有两个:⼀是所引⽤的函数、变量不存在、拼写不正确或者使⽤错误;其次可能使⽤了不同版本的连接库。
  以下是可能产⽣LNK2001错误的原因:
  ⼀.由于编码错误导致的LNK2001。
  1.不相匹配的程序代码或模块定义(.DEF)⽂件能导致LNK2001。例如,  如果在C++源⽂件内声明了⼀变量“var1”,却试图在另⼀⽂件内以变量 “VAR1”访问该变量,                  将发⽣该错误。
  2.如果使⽤的内联函数是在.CPP⽂件内定义的,⽽不是在头⽂件内定义将导致LNK2001错误。
  3.调⽤函数时如果所⽤的参数类型同函数声明时的类型不符将会产⽣LNK2001。
  4.试图从基类的构造函数或析构函数中调⽤虚拟函数时将会导致LNK2001。
5.要注意函数和变量的可公⽤性,只有全局变量、函数是可公⽤的。静态函数和静态变量具有相同的使⽤范围限制。当试图从⽂件外部访问任何没有在该⽂件内声明的静态变量时将导致编译错误或LNK2001。函数内声明的变量(局部变量)只能在该函数的范围内使⽤。C++的全局常量只有静态连接性能。这不同于C,如果试图在                C++的多个⽂件内使⽤全局变量也会产⽣LNK2001错误。⼀种解决的⽅法是需要时在头⽂件中加⼊该常量的初始化代码,并在.CPP⽂件中包含该头⽂件;另⼀种⽅法是使⽤时给该变量赋以常数。
  ⼆.由于编译和链接的设置⽽造成的LNK2001
  1.如果编译时使⽤的是/NOD(/NODEFAULTLIB)选项,程序所需要的运⾏库和MFC库在连接时由编译器写⼊⽬标⽂件模块,但除⾮在⽂件中明确包含这些库名,否则这些库不会被链接进⼯程⽂件。在这种情况下使⽤/NOD将导致错误LNK2001。
  2.如果没有为wWinMainCRTStartup设定程序⼊⼝,在使⽤Unicode和MFC时将得到“unresolved  ext
ernal  on  _WinMain@16”的LNK2001错误信息。
  3.使⽤/MD选项编译时,既然所有的运⾏库都被保留在动态链接库之内,源⽂件中对“func”的引⽤,在⽬标⽂件⾥即对“__imp__func”  的引⽤。如果试图使⽤静态LIBC.LIB                  或LIBCMT.LIB进⾏连接,将在__imp__func上发⽣LNK2001;如果不使⽤/MD选项编译,在使⽤MSVCxx.LIB连接时也会发⽣LNK2001。
  4.使⽤/ML选项编译时,如⽤LIBCMT.LIB链接会在_errno上发⽣LNK2001。
  5.当编译调试版的应⽤程序时,如果采⽤发⾏版模态库进⾏连接也会产⽣LNK2001;同样,使⽤调试版模态库连接发⾏版应⽤程序时也会产⽣相同的问题。
  6.不同版本的库和编译器的混合使⽤也能产⽣问题,因为新版的库⾥可能包含早先的版本没有的符号和说明。
  7.在不同的模块使⽤内联和⾮内联的编译选项能够导致LNK2001。如果创建C++库时打开了函数内联(/Ob1或/Ob2),但是在描述该函数的相应头⽂件⾥却关闭了函数内联(没有inline关键字),这时将得到该错误信息。为避免该问题的发⽣,应该在相应的头⽂件中⽤inline关键字标志内联函数。
析构函数的定义  8.不正确的/SUBSYSTEM或/ENTRY设置也能导致LNK2001。
  其实,产⽣LNK2001的原因还有很多,以上的原因只是⼀部分⽽已,对初学者来说这些就够理解⼀阵⼦了。但是,分析错误原因的⽬的是为了避免错误的发⽣LNK2001错误虽然⽐较困难,但是只要注意到了上述问题,还是能够避免和予以解决的。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。