Linux でのセグメンテーション違反の検出
Q: サードパーティのライブラリでセグメンテーション違反が発生していますが、根本的な問題を解決します。 gcc を使用して Linux でこれらの障害を検出する、クロスプラットフォームまたはプラットフォーム固有のソリューションはありますか?
A: Linux では、セグメンテーション フォールトを例外として処理できます。プログラムがこのような障害に遭遇すると、SIGSEGV シグナルを受け取ります。シグナル ハンドラーを設定することで、このシグナルをインターセプトし、その影響を軽減できます。
セグメンテーション フォールトを例外に変換するには、次のコード スニペットを利用できます:
try { *(int*) 0 = 0; } catch (std::exception& e) { std::cerrこのコードは無効なメモリ位置にアクセスしようとしているため、セグメンテーション違反が発生します。ただし、try-catch ブロックは例外をキャッチし、エラー メッセージを出力します。
上記のライブラリは、すぐに使用できる x86 および x86-64 アーキテクチャをサポートするクロスプラットフォーム バックエンドを提供します。さらに、互換性を拡張するために、gcc ソース内の libjava からバックエンドを取得できます。
免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。
Copyright© 2022 湘ICP备2022001581号-3