C# 11의 새로운 기능
추천 자료: ASP.NET Core 인증 및 권한 부여
C# 11 관련 .NET Conf 동영상
원시 문자열 리터럴(Raw string literals)
이미 우리는 @
기호를 사용하여 문자열에서 이스케이프 문자를 처리할 수 있습니다.
string anyString = "string";
원시 문자열 리터럴은 문자열 리터럴의 새 형식입니다. 원시 문자열 리터럴은 이스케이프 시퀀스를 요구하지 않고 공백, 새 줄, 포함된 따옴표, 기타 특수 문자를 비롯한 임의의 텍스트를 포함할 수 있습니다. 원시 문자열 리터럴은 세 개 이상의 큰따옴표(""") 문자로 시작합니다. 이는 동일한 수의 큰따옴표로 끝납니다. 일반적으로 원시 문자열 리터럴은 한 줄에 세 개의 큰따옴표를 사용하여 문자열을 시작하고 별도의 줄에 세 개의 큰따옴표를 사용하여 문자열을 종료합니다. 여는 따옴표와 닫는 따옴표 앞의 줄 바꿈은 최종 콘텐츠에 포함되지 않습니다.
string longMessage = """
This is a long message.
It has several lines.
Some are indented
more than others.
Some should start at the first column.
Some have "quoted text" in them.
""";
닫는 큰따옴표 왼쪽의 공백은 문자열 리터럴에서 제거됩니다.
HTML 태그를 따로 변환없이 저장하고 출력할 때 원시 문자열 리터럴이 편리합니다.
string htmlTags = """<html lang="ko" />""";
Console.WriteLine(htmlTags); // <html lang="ko" />
원시 문자열 리터럴을 문자열 보간과 결합하여 출력 텍스트에 중괄호를 포함할 수 있습니다. 여러 $
문자는 보간을 시작하고 종료하는 연속 중괄호 수를 나타냅니다.
string language = "ko";
string htmlTags = $"""<html lang="{lanugage}" />""";
Console.WriteLine(htmlTags); // <html lang="ko" />
var location = $$"""
You are at {{{Longitude}}, {{Latitude}}}
""";
앞의 예제에서는 두 개의 중괄호가 보간을 시작하고 종료되도록 지정합니다. 세 번째 반복된 여는 중괄호와 닫는 중괄호가 출력 문자열에 포함됩니다.
JSON 데이터를 문자열로 보관하고 출력하는 경우라면 원시 문자열 리터럴이 진가를 발휘합니다.
var json = "";
추천 자료: .NET Blazor에 대해 알아보시겠어요? .NET Blazor 알아보기를 확인해보세요!