1 C++程序出现illegal instruction 崩溃
1.1 程序出现illegal instruction的场景
这几天在修复一个C++程序的bug,这个程序上线之后在极少数客户的机器上出现了崩溃,通过加载dump文件排查,发现是出现了illegal instruction的报错,然后通过pdb文件的精准定位,发现崩溃的地方竟然是在C++标准库的std::unordered
的reserve
方法,这让人匪夷所思,一般来讲C++标准库是不会出问题的。
1.2 问题解决过程
由于极少量机器出现了崩溃,所以我最开始是使用try catch
块进行异常捕获的,但是在std::unordered
的reserve
方法不会抛出异常,直接崩溃,这让人实在是匪夷所思。
之后通过下面的一些博文:
- https://cloud-atlas.readthedocs.io/zh-cn/latest/kernel/tracing/illegal_instruction_core_dumped.html
- https://www.cnblogs.com/yutongqing/p/6823385.html
- https://www.quora.com/How-can-I-fix-a-0xC000001D-Illegal-Instruction-error-in-Visual-C-2019-while-installing-OpenCV-error-in-gfluidimgproc_func-hpp-library
猜想是不是cpu指令集的问题,出现crash的机器的cpu不支持编译时所设置的指令集。
我的程序的指令集在VS中设置的是/arch:AVX2
然后在出现crash的机器上,使用cpu-z程序发现该cpu不支持AVX2
指令集!问题找到了,就是cpu指令集的问题。
1.3 解决方法
如果是使用Visual Studio编译程序,则将代码生成 - 启用增强指令集,修改为未设置,即不使用任何cpu指令集优化,缺点就是执行速度会慢一点,优点就是不会因为指令集的问题导致程序异常。
本文作者:StubbornHuang
版权声明:本文为站长原创文章,如果转载请注明原文链接!
原文标题:C++ – 排查illegal instruction崩溃问题以及解决方法
原文链接:https://www.stubbornhuang.com/3047/
发布于:2024年07月03日 21:31:45
修改于:2024年07月03日 21:32:04
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
评论
52