昨天编程时,碰上一个极其诡异的问题,在carbide C++下生成写的一个程序时出错:
Undefined symbol: 'int RConnectionMonitor::ConnectL(void) (?ConnectL@RConnectionMonitor@@QAEHXZ)'
……(全是函数未定义的错误)
由于是编译通过了,而且出错的函数全部都是在一个头文件中申明的。
首先想到的第一种可能,忘加connmon.lib库了,在mmp文件中LIBRARY行加上connmon.lib,每个函数对应的lib库可以在SDK中查到。
可加上库后,还是同样的错误。由于以前碰过C中由于文件头文件的顺序而导致的某一种错误而死活编译不过。于是把各头文件顺序各种改啊,但仍然还是同样的错误。事后想想,既然是编译过了,是定义出问题,那和头文件就没关系了,只是当时没想到,白费了很多功夫。
然后,用对待很多诡异问题的惯用办法,关了carbide C++,再开,生成,不过。关机,再开,生成,还是不过。
最后,无奈只好去找是不是connmon.lib这个库文件就没有啊,结果也有。但再一细看,发现connmon.lib这个文件只有10KB,大小感觉不对啊,一看别的文件都有几十K而且修改日期都是07年或者08年,而connmon.lib文件居然是前两天修改过的。找到别人机器上的connmon.lib文件一看,果然大小时间都不对。拷过来覆盖掉,再生成果然就通过了。
库文件能被我修改?!哎……不知道为什么能被修改,那个文件我之前没碰过,上网查也没有结果,只能说这个问题太诡异。结论是没有机器干不出来的错,只有你想不到的错。不过能查出来还是很高兴的哈~^_^