Null 条件演算子 (C# および Visual Basic)Null-conditional Operators (C# and Visual Basic)

メンバー アクセス (?.) またはインデックス (?[) 操作を実行する前に、null をテストするために使用されます。Used to test for null before performing a member access (?.) or index (?[) operation. これらの演算子を使用すると、null チェックの処理のために記述するコードを少なくすることができます (特に、データ構造を下っていく場合)。These operators help you write less code to handle null checks, especially for descending into data structures.

int? length = customers?.Length; // null if customers is null   
Customer first = customers?[0];  // null if customers is null  
int? count = customers?[0]?.Orders?.Count();  // null if customers, the first customer, or Orders is null  
Dim length = customers?.Length  ' null if customers is null  
Dim first as Customer = customers?(0)  ' null if customers is null  
Dim count as Integer? = customers?(0)?.Orders?.Count()  ' null if customers, the first customer, or Orders is null  

最後の例は、null 条件演算子がショート サーキットであることを示します。The last example demonstrates that the null-condition operators are short-circuiting. 条件付きのメンバー アクセスおよびインデックス操作のチェーンの 1 つの演算が null を返す場合、チェーンの実行の残りの部分は停止します。If one operation in a chain of conditional member access and index operation returns null, then the rest of the chain’s execution stops. 式内の優先度の低い他の演算は続行されます。Other operations with lower precedence in the expression continue. たとえば、次の 2 行目にある E が実行され、?? 演算と == 演算が実行されます。For example, E in the following executes in the second line, and the ?? and == operations execute. 1 行目の ?? はショート サーキットであり、左辺が null 以外に評価されると、E は実行されません。In the first line, the ?? short circuits and E does not execute when the left side evaluates to non-null.

A?.B?.C?[0] ?? E  
A?.B?.C?[0] == E  
A?.B?.C?(0) ?? E  
A?.B?.C?(0) == E  

null 条件メンバー アクセスの別の用途は、はるかに少ないコードのスレッド セーフな方法でデリゲートを呼び出すことです。Another use for the null-condition member access is invoking delegates in a thread-safe way with much less code. 従来の方法には、次のようなコードが必要です。The old way requires code like the following:

var handler = this.PropertyChanged;  
if (handler != null)  
    handler(…);
Dim handler = AddressOf(Me.PropertyChanged)  
If handler IsNot Nothing  
    Call handler(…)  

新しい方法は格段に単純です。The new way is much simpler:

PropertyChanged?.Invoke(e)  
PropertyChanged?.Invoke(e)

コンパイラが PropertyChanged を評価するためのコードを一度しか生成せず、一時変数に結果が保持されるため、新しい方法はスレッド セーフです。The new way is thread-safe because the compiler generates code to evaluate PropertyChanged one time only, keeping the result in a temporary variable.

null 条件デリゲート呼び出し構文 PropertyChanged?(e) がないため、Invoke メソッドを明示的に呼び出す必要があります。You need to explicitly call the Invoke method because there is no null-conditional delegate invocation syntax PropertyChanged?(e). それを許可するためのあいまいな解析状況が多すぎました。There were too many ambiguous parsing situations to allow it.

言語仕様Language Specifications

詳細については、「C# 言語の仕様」を参照してください。 言語仕様は、C# の構文と使用法に関する信頼性のある情報源です。

詳しくは、「Visual Basic 言語リファレンス」をご覧ください。For more information, see the Visual Basic Language Reference.

関連項目See Also

??(null 合体演算子)?? (null-coalescing operator)
C# リファレンスC# Reference
C# プログラミング ガイドC# Programming Guide
Visual Basic の言語リファレンスVisual Basic Language Reference
Visual Basic プログラミング ガイドVisual Basic Programming Guide