C#
2021.05.09 20:33

C# ?? 및 ??=, ?. 연산자

조회 수 3130 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

+ - Up Down Comment Print
?

단축키

Prev이전 문서

Next다음 문서

+ - Up Down Comment Print

C# 코드를 작성하다보면 null 체크를 해야하는 경우가 꽤 많다. if 문을 사용해서 null 체크를 하다보면 코드가 길어지고 가독성이 떨어지게된다.

그래서 C# 에서는 간단한 연산자로 null 체크를 할 수 있는 방법을 제공한다! 잘 사용하면 코드 가독성도 높이고 에러 발생도 미리 예방할 수 있다.


연산자 ?. 및 ?[]

피연산자가 null 이 아닌 것으로 평가되었을 때만 멤버 액세스 ?. 또는 요소 액세스 ?[] 연산을 피연산자에게 적용하며, 그렇지 않으면 null 을 반환한다.

  • a가 null로 평가되면 a?.x 또는 a?[x]의 결과는 null이다.
  • a가 null이 아닌 것으로 평가되면 a?.x 또는 a?[x]의 결과는 각각 a.x또는 a[x]의 결과와 같다.

Null 조건부 연산자는 단락 연산자이다. 즉 조건부 멤버나 요소 액세스 작업의 한 체인의 작업에서 null을 반환하면 나머지 체인은 실행되지 않는다. 다음 예제에서 A가 null로 평가되면 B가 평가되지 않고, A또는 B가 null로 평가되면 C가 평가되지 않는다.

A?.B?.Do(C);
A?.B?[C];

연산자 ?? 및 ??=

null 병합 연산자 ??는 null이 아닌 경우 왼쪽 피연산자의 값을 반환한다. 그렇지 않으면 오른쪽 피연산자를 평가하고 그 결과를 반환한다. 왼쪽 피연산자가 null이 아닌 것으로 평가되면 ?? 연산자는 오른쪽 피연산자를 평가하지 않는다.

C# 8.0 이상에서 사용할 수 있는 null 병합 할당 연산자 ??=는 왼쪽 피연산자가 null로 계산되는 경우에만 오른쪽 피연산자의 값을 왼쪽 피연산자에 대입한다. 왼쪽 피연산자가 null이 아닌 것으로 평가되면 ??= 연산자는 오른쪽 피연산자를 평가하지 않는다.

List<int> numbers = null;
int? a = null;

(numbers ??= new List<int>()).Add(5);
Console.WriteLine(string.Join(" ", numbers));  // output: 5

numbers.Add(a ??= 0);
Console.WriteLine(string.Join(" ", numbers));  // output: 5 0
Console.WriteLine(a);  // output: 0

??= 연산자의 왼쪽 피연산자는 변수, 속성 또는 인덱서 요소여야 합니다.
C# 7.3 이전 버전에서 ?? 연산자의 왼쪽 피연산자 형식은 참조 형식 또는 Nullable 값 형식이어야 합니다.
C# 8.0부터 이 요구 사항이 다음과 같이 바뀝니다. ?? 및 ??= 연산자의 왼쪽 피연산자 형식은 null을 허용하지 않는 값 형식일 수 없습니다. 특히 C# 8.0부터 비제한 형식 매개 변수와 함께 null 병합 연산자를 사용할 수 있습니다.


예제

유저 데이터를 받아오는 코드에서 사용 예제

var userData = userDB.ToDictionary();

UserManager.Instance.CurrentUser = new User {
	uid = userData["uid"]?.ToString() ?? "",
	email = userData["email"]?.ToString() ?? "",
	name = userData["name"]?.ToString() ?? "UnNamed",
	licenseId = userData["licenseId"]?.ToString() ?? "",
};

참고 자료

?? 및 ??= 연산자 - C# 참조

멤버 액세스 연산자 및 식 - C# 참조


Dreamy의 코드 스크랩

내가 모으고 내가 보는

List of Articles
번호 분류 제목 날짜 조회 수 추천 수
506 LINUX awk 명령어 사용법 1 2006.02.16 114791 15
505 MFC CString 에서 형변환 함수들 총정리 2010.11.29 102811 0
504 Android adb am 명령어 ; app 실행 및 Intent 전송 2013.08.12 100498 0
503 Android [GIT 사용법] Git Tutorial 2011.12.26 96599 0
502 일반 ┗ bat(배치)파일 문법 2007.08.06 93709 8
501 LINUX [Shell Script] 리눅스 쉘(Shell) 스크립트 2014.09.23 86896 0
500 JAVA JAVA String 클래스 메소드 정리 1 2015.02.05 85063 0
499 LINUX [Shell Script] 쉘 스크립트에서의 사칙연산과 문자열 자르기 2014.11.01 81838 0
498 C# StringBuilder로 문자열 처리를 빠르게 2012.12.04 78024 0
497 LINUX du 명령어 사용법(디스크 용량 확인) 1 2012.05.31 77541 0
496 Python BeautifulSoup으로 웹에 있는 데이터 긁어오기 2013.04.08 77032 0
495 Android [GIT 사용법] 초보자가 알아두면 좋을 명령어 정리 1 2011.12.26 66626 0
494 LINUX errno.h - system error numbers 2013.01.09 65978 0
493 일반 findstr 사용법 - window용 find, grep 명령 2014.02.04 63226 0
492 MFC API를 이용하는 유니코드와 ANSI 문자열간의 변환 방법 2006.04.14 63222 0
목록
Board Pagination ‹ Prev 1 2 3 4 5 6 7 8 9 10 ... 34 Next ›
/ 34

나눔글꼴 설치 안내


이 PC에는 나눔글꼴이 설치되어 있지 않습니다.

이 사이트를 나눔글꼴로 보기 위해서는
나눔글꼴을 설치해야 합니다.

설치 취소

Designed by sketchbooks.co.kr / sketchbook5 board skin

Sketchbook5, 스케치북5

Sketchbook5, 스케치북5

Sketchbook5, 스케치북5

Sketchbook5, 스케치북5