一个C++代码DEBUG时跳到错误的函数中的怪问题
近日写了一个加解密库,因为要在C#中访问,因此该库全部定义为API接口并通过.def文件申明外漏的接口,Debug版本的输出文件是DDToolsD.dll,Release版本的输出文件是DDTools.dll
其中有一个接口用于通过SHA1计算HASH,因为要在C#中调用,将HASH值转换为HEX Code以后返回
生成HEX Code的函数名为Buffer2Hex,解码HEX Code的函数名为Hex2Buffer,在调试SHA1接口的时候发现,代码中明明写的是调用Buffer2Hex,但是程序总是会跳到Hex2Buffer中
第一反应就是PDB与代码不匹配,删除ncb文件,删除Debug目录,删除DLL输出目录,Rebuild一下,问题照旧。
第二反应是.def文件定义的接口不对,仔细检查了,没有发现问题
第三反应是VS用了比较老的缓存中的DLL文件,看了一下modules中的定义发现路径是正确的,但是link的文件好像不对,debug版本link的是DDTools.dll,正确的应该是DDToolsD.dll
找了一下原因,发现在库的.def文件里面写了LIBRARY="DDTools"字样
查了一下MSDN原始描述是:
The first statement in the file must be the LIBRARY statement. This statement identifies the .def file as belonging to a DLL. The LIBRARY statement is followed by the name of the DLL. The linker places this name in the DLL's import library.
问题出在这里,LIBRARY中定义的DDTools会包含在输出的lib中,因此上层在调用的时候会弄错文件
在Debug与Release分别输出DDTools.dll解决了这个问题,直接删除LIBRARY="DDTools"字样也解决了这个问题
That's all.