C#
2021.05.09 20:33

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

조회 수 5518 댓글 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
번호 분류 제목 날짜 조회 수 추천 수
495 업무 Back-End 관련 정보 2022.05.17 3722 0
494 C# C#의 $으로 문자열 보간하기 2022.04.28 6477 0
493 일반 3D프린트 가이드 모음 2022.04.02 4781 0
492 일반 프리미어 프로 Premier Pro secret 2022.02.04 0 0
491 Android [Git] git add 취소하기, git commit 취소하기, git push 취소하기 2021.09.30 8028 0
490 일반 엑셀 Excel 데이터 시각화 (엑셀 사용 Tip) 2021.08.25 5116 0
489 Android 안드로이드 스마트 폰 화면 미러링: scrcpy 사용법 2021.08.18 40730 0
488 일반 Cakewalk 단축키 정리 2021.07.20 6240 0
487 일반 Cakewalk secret 2021.07.20 0 0
486 C# C# JSON 파싱(parsing): Newtonsoft 및 System.Text.Json 2021.05.15 13371 0
» C# C# ?? 및 ??=, ?. 연산자 2021.05.09 5518 0
484 Android Android Animation Interpolator(보간기) 종류 2020.12.01 7545 0
483 Android Android Animation XML 사용 2020.12.01 5893 0
482 Pi 라즈베리파이 웹페이지 자동 실행 설정 방법 secret 2020.11.03 0 0
481 PHP [PHP] .php 확장자 없이 URL 접속하기 2020.10.26 6956 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