Nullalbe 값 형식(C# 참조)
Null 허용 값 형식 T?는 기본 값 형식 T의 모든 값과 추가 null 값을 나타냅니다. 예를 들어 bool? 변수에는 다음 세 가지 값 중 하나를 할당할 수 있습니다. true, false, null. 기본 값 형식 T는 null 허용 값 형식 자체일 수 없습니다.
참고
C# 8.0에서는 nullable 참조 형식 기능을 소개합니다. 자세한 내용은 nullable 참조 형식을 참조하세요. Null 허용 값 형식은 C# 2부터 사용할 수 있습니다.
Null 허용 값 형식은 제네릭 System.Nullable<T> 구조체의 인스턴스입니다. 서로 교환 가능한 형식인 Nullable<T> 또는 T? 중 하나에서 기본 값 형식 T의 null 허용 값 형식을 참조할 수 있습니다.
기본 값 형식의 정의되지 않은 값을 표시해야 하는 경우 일반적으로 null 허용 값 형식을 사용합니다. 예를 들어 부울(bool) 변수는 true 또는 false만 가능합니다. 그러나 일부 애플리케이션에서는 변수 값이 정의되지 않았거나 누락될 수 있습니다. 예를 들어 데이터베이스 필드는 true 또는 false를 포함하거나 아무 값도 없을 수 있습니다(즉 NULL). 이러한 시나리오에서 bool? 형식을 사용할 수 있습니다.
선언 및 할당
값 형식이 암시적으로 해당 null 허용 값 형식으로 변환될 수 있기 때문에 기본 값 형식에서와 마찬가지로 null 허용 값 형식의 변수에 값을 할당할 수 있습니다. null 값을 할당할 수도 있습니다. 예를 들어:
경고
찾으시는 샘플이 이동된 것으로 보입니다. 현재 이 문제를 해결하기 위해 노력하고 있습니다.
Null 허용 값 형식의 기본값은 null을 나타냅니다. 즉, Nullable<T>.HasValue 속성이 false을 반환하는 인스턴스입니다.
Null 허용 값 형식의 인스턴스 검사
C# 7.0부터 is형식 패턴 포함 연산자를 사용하여 null 허용 값 형식의 인스턴스에서 null 여부를 검사하고 기본 형식의 값을 검색할 수 있습니다.
경고
찾으시는 샘플이 이동된 것으로 보입니다. 현재 이 문제를 해결하기 위해 노력하고 있습니다.
항상 다음 읽기 전용 속성을 사용하여 null 허용 값 형식 변수의 값을 검사하고 가져올 수 있습니다.
다음 예제는 HasValue 속성을 사용하여 표시하기 전에 변수가 값을 포함하는지 여부를 테스트합니다.
경고
찾으시는 샘플이 이동된 것으로 보입니다. 현재 이 문제를 해결하기 위해 노력하고 있습니다.
다음 예제와 같이 HasValue 속성을 사용하는 대신 nullable 값 형식 변수를 null과 비교할 수도 있습니다.
경고
찾으시는 샘플이 이동된 것으로 보입니다. 현재 이 문제를 해결하기 위해 노력하고 있습니다.
nullable 값 형식에서 기본 형식으로 변환
Null 허용 값 형식의 값을 null을 허용하지 않는 값 형식 변수에 할당하려는 경우 null 대신 할당할 값을 지정해야 할 수 있습니다. null 병합 연산자??를 사용하여 이 작업을 수행할 수 있습니다. Nullable<T>.GetValueOrDefault(T) 메서드를 동일한 용도로 사용할 수도 있습니다.
경고
찾으시는 샘플이 이동된 것으로 보입니다. 현재 이 문제를 해결하기 위해 노력하고 있습니다.
null 대신 기본 값 형식의 기본값을 사용하려면 Nullable<T>.GetValueOrDefault() 메서드를 사용합니다.
다음 예제와 같이 null 허용 값 형식을 null을 허용하지 않는 형식으로 명시적으로 캐스트할 수도 있습니다.
경고
찾으시는 샘플이 이동된 것으로 보입니다. 현재 이 문제를 해결하기 위해 노력하고 있습니다.
런타임 시 nullable 값 형식의 값이 null인 경우 명시적 캐스트는 InvalidOperationException을 throw합니다.
null을 허용하지 않는 값 형식 T는 해당 null 허용 값 형식 T?로 암시적으로 변환될 수 있습니다.
리프트 연산자
미리 정의된 단항 및 이항 연산자 또는 값 형식 T에서 지원하는 오버로드된 연산자는 해당 null 허용 값 형식 T?에서도 지원합니다. 리프트 연산자라고도 하는 이러한 연산자는 하나 또는 두 개의 피연산자가 null인 경우 null 값을 생성하고, 그렇지 않으면 연산자는 포함된 피연산자 값을 사용하여 결과를 계산합니다. 예를 들어:
경고
찾으시는 샘플이 이동된 것으로 보입니다. 현재 이 문제를 해결하기 위해 노력하고 있습니다.
참고
| 형식의 경우 미리 정의된 bool? 및 & 연산자는 이 섹션에서 설명된 규칙을 따르지 않습니다. 연산자 평가의 결과는 피연산자 중 하나가 null인 경우에도 Null이 아닐 수 있습니다. 자세한 내용은 부울 논리 연산자 문서의 Nullable 부울 논리 연산자 섹션을 참조하세요.
비교 연산자 <, >, <= 및 >=의 경우 피연산자 중 하나 또는 둘 모두가 null이면 결과는 false입니다. 그렇지 않으면 포함된 피연산자 값을 비교합니다. 특정 비교(예: <=)에서는 false를 반환하고 그 반대의 비교(>)에서는 true를 반환한다고 가정하지 마십시오. 다음 예제에서는 10이
- null보다 크지도, 같지도 않고
- null보다 작지도 않음을 보여줍니다.
경고
찾으시는 샘플이 이동된 것으로 보입니다. 현재 이 문제를 해결하기 위해 노력하고 있습니다.
같음 연산자 ==의 경우 두 피연산자 모두 null이면 결과는 true이고 피연산자 중 하나만 null이면 결과는 false입니다. 그렇지 않으면 포함된 피연산자 값을 비교합니다.
같지 않음 연산자 !=의 경우 두 피연산자 모두 null이면 결과는 false이고 피연산자 중 하나만 null이면 결과는 true입니다. 그렇지 않으면 포함된 피연산자 값을 비교합니다.
두 값 형식 사이에 사용자 정의 변환이 있는 경우 해당 null 허용 값 형식 사이에도 같은 변환을 사용할 수 있습니다.
boxing 및 unboxing
Null 허용 값 형식 T?의 인스턴스는 다음과 같이 box됩니다.
다음 예제와 같이 값 형식 T의 boxed 값을 해당 null 허용 값 형식 T?로 unbox할 수 있습니다.
경고
찾으시는 샘플이 이동된 것으로 보입니다. 현재 이 문제를 해결하기 위해 노력하고 있습니다.
Null 허용 값 형식 식별 방법
다음 예제는 System.Type 인스턴스가 구성된 null 허용 값 형식(지정된 형식 매개 변수 T가 포함된 System.Nullable<T> 형식)을 나타내는지 확인하는 방법을 보여 줍니다.
경고
찾으시는 샘플이 이동된 것으로 보입니다. 현재 이 문제를 해결하기 위해 노력하고 있습니다.
예제에서와 같이 typeof 연산자를 사용하여 System.Type 인스턴스를 만듭니다.
인스턴스가 있는지 nullable 값 형식인지 여부를 확인하려는 경우 위의 코드로 테스트되도록 Type 인스턴스를 가져오는 데 Object.GetType 메서드를 사용하지 마세요. nullable 값 형식의 인스턴스에서 Object.GetType 메서드를 호출하는 경우 인스턴스는 Object로 boxing됩니다. Null 허용 값 형식의 Null이 아닌 인스턴스의 boxing은 기본 형식 값의 boxing과 동일하며, GetType는 null 허용 값 형식의 기본 형식을 나타내는 Type 인스턴스를 반환합니다.
경고
찾으시는 샘플이 이동된 것으로 보입니다. 현재 이 문제를 해결하기 위해 노력하고 있습니다.
그리고 인스턴스가 null 허용 값 형식인지 여부를 확인하는 데 is 연산자를 사용하지 마세요. 다음 예제에서와 같이 null 허용 값 형식 인스턴스와 is 연산자를 사용하는 해당 형식 인스턴스를 구분할 수 없습니다.
경고
찾으시는 샘플이 이동된 것으로 보입니다. 현재 이 문제를 해결하기 위해 노력하고 있습니다.
다음 예제에서 제공된 코드를 사용하여 인스턴스가 nullable 값 형식인지 여부를 확인할 수 있습니다.
경고
찾으시는 샘플이 이동된 것으로 보입니다. 현재 이 문제를 해결하기 위해 노력하고 있습니다.
참고
이 섹션에서 설명하는 방법은 nullable 참조 형식의 경우에는 적용되지 않습니다.
C# 언어 사양
자세한 내용은 C# 언어 사양의 다음 섹션을 참조하세요.
참조
피드백
다음에 대한 피드백 보내기
이 제품
이 페이지
현재 이 문서에 대한 피드백이 없습니다. 페이지 피드백이 여기에 표시됩니다.
?? 및 ??= 연산자(C# 참조)
null 병합 연산자 ??는 null이 아닌 경우 왼쪽 피연산자의 값을 반환합니다. 그렇지 않으면 오른쪽 피연자를 평가하고 그 결과를 반환합니다. 왼쪽 피연산자가 null이 아닌 것으로 평가되면 ?? 연산자는 오른쪽 피연산자를 평가하지 않습니다.
C# 8.0 이상에서 사용할 수 있는 null 병합 할당 연산자 ??=는 왼쪽 피연산자가 null로 계산되는 경우에만 오른쪽 피연산자의 값을 왼쪽 피연산자에 대입합니다. 왼쪽 피연산자가 null이 아닌 것으로 평가되면 ??= 연산자는 오른쪽 피연산자를 평가하지 않습니다.
경고
찾으시는 샘플이 이동된 것으로 보입니다. 현재 이 문제를 해결하기 위해 노력하고 있습니다.
??= 연산자의 왼쪽 피연산자는 변수, 속성 또는 인덱서 요소여야 합니다.
C# 7.3 이전 버전에서 ?? 연산자의 왼쪽 피연산자 형식은 참조 형식 또는 Nullable 값 형식이어야 합니다. C# 8.0부터 이 요구 사항이 다음과 같이 바뀝니다. ?? 및 ??= 연산자의 왼쪽 피연산자 형식은 null을 허용하지 않는 값 형식일 수 없습니다. 특히 C# 8.0부터 비제한 형식 매개 변수와 함께 null 병합 연산자를 사용할 수 있습니다.
경고
찾으시는 샘플이 이동된 것으로 보입니다. 현재 이 문제를 해결하기 위해 노력하고 있습니다.
null 병합 연산자는 오른쪽 결합입니다. 즉, 양식의 식이
C#복사
a ?? b ?? c d ??= e ??= f
다음과 같이 계산됩니다.
C#복사
a ?? (b ?? c) d ??= (e ??= f)
예
?? 및 ??= 연산자는 다음과 같은 시나리오에서 유용할 수 있습니다.
-
null 병합 연산자 ?. 및 ?[]가 있는 식에서 ?? 연산자를 사용하여 null 조건부 연산을 사용한 식의 결과가 null인 경우 평가하는 대체 식을 제공할 수 있습니다.
경고
찾으시는 샘플이 이동된 것으로 보입니다. 현재 이 문제를 해결하기 위해 노력하고 있습니다.
-
nullable 값 형식을 사용하고 기본값 유형의 값을 제공해야 할 때 ?? 연산자를 사용하여 nullable 값이 null인 경우 제공할 값을 지정합니다.
경고
찾으시는 샘플이 이동된 것으로 보입니다. 현재 이 문제를 해결하기 위해 노력하고 있습니다.
nullable 형식 값이 null일 때 사용될 값이 기본 값 형식의 기본 값이어야 하는 경우 Nullable<T>.GetValueOrDefault() 메서드를 사용합니다.
-
C# 7.0부터 ?? 연산자의 오른쪽 피연산자로 throw 식을 사용하여 인수 확인 코드를 보다 간결하게 만들 수 있습니다.
경고
찾으시는 샘플이 이동된 것으로 보입니다. 현재 이 문제를 해결하기 위해 노력하고 있습니다.
앞의 예제에서는 식 본문 멤버를 사용하여 속성을 정의하는 방법도 보여줍니다.
-
C# 8.0부터 ??= 연산자를 사용하여 다음 양식의 코드를
C#복사
if (variable is null) { variable = expression; }
다음 코드로 바꿉니다.
C#복사
variable ??= expression;
연산자 오버로드 가능성
?? 및 ??= 연산자는 오버로드할 수 없습니다.
C# 언어 사양
?? 연산자에 대한 자세한 내용은 C# 언어 사양의 null 병합 연산자 섹션을 참조하세요.
??= 연산자에 대한 자세한 내용은 기능 제안 노트를 참조하세요.
참조
피드백
다음에 대한 피드백 보내기
이 제품
이 페이지
현재 이 문서에 대한 피드백이 없습니다. 페이지 피드백이 여기에 표시됩니다.