今天发现,如果dll库函数里用了一个std::string&类型的参数,且在使用时修改了string的内容,那么可能会因为调用者用的内存分配器与dll库里的不一致,而导致崩溃等严重问题。
神奇的是,同事把dll改为lib,就解决了这个问题。准确来说,lib方式,库内的函数调用new函数时,也会跳转到已经被重载的全局new上面去。
仔细看了下VS2013的工程设置,确实,如果是LIB项目,那么就没有链接器的选项,dll和exe就有。
说明dll和lib的确有本质区别,特此一记。
以前看过《链接,装载与库》,自认为比较了解dll,看来还是有很多知识漏洞。
C++真复杂。