警告 C26823
null ポインター 'variable' を逆参照する (lifetime.1)
解説
C および C++ では、null ポインターの逆参照が頻繁に問題になります。 このような問題に対処するためのいくつかのチェックがあります。 比較については、この ブログの投稿 を参照してください。 分析エンジンは、ポインターの値が null である可能性があることを推論し、そのポインターが逆参照されることを確認すると、 C26823
警告を出力します。 C26822を有効にできるのは、より緩やかな分析の場合のみです。 このチェックでは、 SAL 注釈 コードの不変性を記述するための gsl::not_null
もサポートされています。
例
void invalidate(int **pp);
void condition_null_dereference_invalidated(int* p)
{
if (p)
return;
invalidate(&p);
// The call above could reset the value of `p`, thus the low confidence warning.
*p = 5; // warning: C26823
}
この警告を解決するには、null チェックを追加することで、コードに null ポインターの逆参照がないことを確認します。 コードが正しいことがわかった場合は、多くの場合、 gsl::not_null
または SAL 注釈を使用して誤検知の結果を修正できます。 これらの注釈の一部を使用する方法の例を次に示します。
_Notnull_ int *get_my_ptr();
gsl::not_null<int *> get_my_ptr2();
void local_analysis(int *p) {
_Analysis_assume_(p != nullptr);
*p = 42;
}
void local_analysis2(_In_ int *p) {
int a = *p;
}