28

Clang有各种消毒剂,可以打开以在运行时发现问题。
但是,有些消毒剂我不能一起使用。这是为什么?

clang++-3.9 -std=c++1z -g -fsanitize=memory -fsanitize=address -o main main.cpp                                                                                   1
clang: error: invalid argument '-fsanitize=address' not allowed with '-fsanitize=memory'

这没什么大不了的,但是当我运行单元测试时,它需要的时间比它应该的要长,因为我为相同的测试创建了多个二进制文件,并分别运行它们中的每一个。

clang++-3.9 -std=c++1z -g -fsanitize=address -o test1 test.cpp
clang++-3.9 -std=c++1z -g -fsanitize=memory -fsanitize=undefined  -o test2 test.cpp
4

1 回答 1

15

我认为问题在于 Asan 和 Msan 都想控制堆,并且都想保留大量内存以用作“影子内存”,以跟踪程序使用的内存的分配和使用情况。

它们不能同时处于活动状态,因为它们会尝试跟踪另一个 sanitizer 正在使用的内存(根据 sanitizer 检查的规则,这可能看起来不是“安全的”)。

这也会导致疯狂的内存使用,因为两个清理程序都会分配额外的内存来跟踪程序使用的每个字节。

也许理论上它们可以重新设计以共享一个共同的框架,这样它们就可以合作而不是发生冲突,但可能有很好的实际原因说明这会很困难,或者会损害性能。

于 2016-07-22T10:02:07.453 回答