1 C++程序出现illegal instruction 崩溃

1.1 程序出现illegal instruction的场景

这几天在修复一个C++程序的bug,这个程序上线之后在极少数客户的机器上出现了崩溃,通过加载dump文件排查,发现是出现了illegal instruction的报错,然后通过pdb文件的精准定位,发现崩溃的地方竟然是在C++标准库的std::unorderedreserve方法,这让人匪夷所思,一般来讲C++标准库是不会出问题的。

1.2 问题解决过程

由于极少量机器出现了崩溃,所以我最开始是使用try catch块进行异常捕获的,但是在std::unorderedreserve方法不会抛出异常,直接崩溃,这让人实在是匪夷所思。

之后通过下面的一些博文:

猜想是不是cpu指令集的问题,出现crash的机器的cpu不支持编译时所设置的指令集。

我的程序的指令集在VS中设置的是/arch:AVX2

C++ – 排查illegal instruction崩溃问题以及解决方法-StubbornHuang Blog

然后在出现crash的机器上,使用cpu-z程序发现该cpu不支持AVX2指令集!问题找到了,就是cpu指令集的问题。

1.3 解决方法

如果是使用Visual Studio编译程序,则将代码生成 - 启用增强指令集,修改为未设置,即不使用任何cpu指令集优化,缺点就是执行速度会慢一点,优点就是不会因为指令集的问题导致程序异常。

C++ – 排查illegal instruction崩溃问题以及解决方法-StubbornHuang Blog