Microsoft MVP성태의 닷넷 이야기
VC++: 135. C++ - string_view의 동작 방식 [링크 복사], [링크+제목 복사]
조회: 341
글쓴 사람
홈페이지
첨부 파일
 

C++ - string_view의 동작 방식

string_view는,

<string_view> operators
; https://docs.microsoft.com/en-us/cpp/standard-library/string-view-operators?view=vs-2019

.NET과 비교하면 Span<T>라고 보시면 됩니다.

C# 7.2 - Span<T>
; https://www.sysnet.pe.kr/2/0/11534

다음과 같이 간단하게 사용해 볼 수 있는데,

#include "stdafx.h"

#include <string>
#include <string_view>
using namespace std;

int main(void)
{
    string_view txt{ "t" };
    string_view qwer = txt.substr(0, 4); // qwer == "t"

    return 0;
}

기존 문자열 버퍼에 대한 "View"를 제공한다는 점에서 string_view는 시작과 끝에 대한 정보만을 가지고 있다는 것을 잊어서는 안 됩니다. 그 한 예로 이제는 string에서 같아진 c_str과 data 함수의 경우,

C++ string의 c_str과 data 함수의 차이점
; https://www.sysnet.pe.kr/2/0/11898

string_view에서는 data 함수만을 제공할 수 있습니다. 그리고 그 data 함수는 (당연히 시작과 끝에 대한 정보만을 가지므로) null('\0') 처리를 하지 않습니다. 예를 들어 다음의 코드를 보면,

{
    char temp[5] = "abcd";
    string_view txt = temp;

    temp[4] = 'e';

    string_view word4 = txt.substr(0, 4); // word4 == "abcd"

    const char* ptr = word4.data(); 
    printf("%s", word4.data()); // null처리가 없으므로 ptr == "abcde...[null이 나올 때까지]...";
}

temp 버퍼에 대한 start와 end 위치만을 보관하고 있는 string_view를 substr한 경우, 표면상으로는 (Watch 창을 통해 확인하면 word4 == "abcd") 4개의 문자만을 가진 텍스트로 보이지만, 그 인스턴스에 대해 data() 함수를 호출하는 경우 결국 반환하는 "char *" 타입은 "끝 정보"를 표현할 수 없으므로, 게다가 "끝 정보"를 나타내기 위해 원본 temp를 변경할 수도 없으므로 null 처리가 안 된 상태로 풀리게 됩니다.

이와 유사하게 remove_suffix 함수도 조심해서 다뤄야 합니다.

basic_string_view::remove_suffix
; https://docs.microsoft.com/ko-kr/cpp/standard-library/basic-string-view-class?view=vs-2019#remove_suffix

다음과 같은 코드의 경우,

{
    char temp[5] = "abcd";
    string_view txt = temp; // txt == "abcd"

    txt.remove_suffix(1); // txt == "abc"

    const char* ptr = txt.data(); // remove_suffix에 상관없이 ptr == "abcd";
    printf("%s", txt.data());
}

remove_suffix를 했지만, data() 함수를 호출하면 substr과 마찬가지로 끝 정보에 대한 변경은 소실됩니다. 어찌 보면, 제 생각에는 data 함수를 (실수의 여지가 있으므로) 오히려 두지 않았어야 하는 것이 옳지 않았나 싶습니다.




참고로 Visual C++의 경우, 만약 빌드 시에 다음과 같은 오류가 발생한다면?

Error C2065 'string_view': undeclared identifier
Error E0020 identifier "string_view" is undefined

프로젝트 속성에서 명시적으로 "ISO C++ 17 Standard(/std:c++17)" 이상의 옵션을 선택해야 합니다.

set_cpp_17.png




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]





[최초 등록일: ]
[최종 수정일: 12/27/2019 ]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer@outlook.com

비밀번호

댓글 쓴 사람
 




1  2  3  4  5  [6]  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
12083정성태12/17/2019528Linux: 27. linux - lldb를 이용한 .NET Core 응용 프로그램의 메모리 덤프 분석 방법 [1]
12082정성태12/17/2019324오류 유형: 585. lsof: WARNING: can't stat() fuse.gvfsd-fuse file system
12081정성태12/16/2019372개발 환경 구성: 465. 로컬 PC에서 개발 중인 ASP.NET Core 웹 응용 프로그램을 다른 PC에서도 접근하는 방법
12080정성태12/16/2019552.NET Framework: 870. C# - 프로세스의 모든 핸들을 열람
12079정성태12/13/2019365오류 유형: 584. 원격 데스크탑(rdp) 환경에서 다중 또는 고용량 파일 복사 시 "Unspecified error" 오류 발생
12078정성태12/13/2019622Linux: 26. .NET Core 응용 프로그램을 위한 메모리 덤프 방법 [1]
12077정성태12/13/2019406Linux: 25. 자주 실행할 명령어 또는 초기 환경을 "~/.bashrc" 파일에 등록
12076정성태12/17/2019542디버깅 기술: 142. Linux - lldb 환경에서 sos 확장 명령어를 이용한 닷넷 프로세스 디버깅 - 배포 방법에 따른 차이
12075정성태12/18/2019573디버깅 기술: 141. Linux - lldb 환경에서 sos 확장 명령어를 이용한 닷넷 프로세스 디버깅
12074정성태12/11/2019388디버깅 기술: 140. windbg/Visual Studio - 값이 변경된 경우를 위한 정지점(BP) 설정(Data Breakpoint)
12073정성태12/10/2019631Linux: 24. Linux/C# - 실행 파일이 아닌 스크립트 형식의 명령어를 Process.Start로 실행하는 방법
12072정성태12/9/2019290오류 유형: 583. iisreset 수행 시 "No such interface supported" 오류
12071정성태12/9/2019384오류 유형: 582. 리눅스 디스크 공간 부족 및 safemode 부팅 방법
12070정성태12/9/2019509오류 유형: 581. resize2fs: Bad magic number in super-block while trying to open /dev/.../root
12069정성태12/19/2019592디버깅 기술: 139. windbg - x64 덤프 분석 시 메서드의 인자 또는 로컬 변수의 값을 확인하는 방법
12068정성태11/28/2019796디버깅 기술: 138. windbg와 Win32 API로 알아보는 Windows Heap 정보 분석 [2]파일 다운로드2
12067정성태11/27/2019589디버깅 기술: 137. 실제 사례를 통해 Debug Diagnostics 도구가 생성한 닷넷 웹 응용 프로그램의 성능 장애 보고서 설명 [1]파일 다운로드1
12066정성태11/27/2019407디버깅 기술: 136. windbg - C# PInvoke 호출 시 마샬링을 담당하는 함수 분석 - OracleCommand.ExecuteReader에서 OpsSql.Prepare2 PInvoke 호출 분석
12065정성태11/25/2019439디버깅 기술: 135. windbg - C# PInvoke 호출 시 마샬링을 담당하는 함수 분석파일 다운로드1
12064정성태11/25/2019715오류 유형: 580. HTTP Error 500.0/500.33 - ANCM In-Process Handler Load Failure
12063정성태11/21/2019474디버깅 기술: 134. windbg - RtlReportCriticalFailure로부터 parameters 정보 찾는 방법
12062정성태12/20/2019398디버깅 기술: 133. windbg - CoTaskMemFree/FreeCoTaskMem에서 발생한 덤프 분석 사례 - 두 번째 이야기
12061정성태11/20/2019431Windows: 165. CoTaskMemAlloc/CoTaskMemFree과 윈도우 Heap의 관계
12060정성태11/21/2019486디버깅 기술: 132. windbg/Visual Studio - HeapFree x64의 동작 분석
12059정성태11/20/2019457디버깅 기술: 131. windbg/Visual Studio - HeapFree x86의 동작 분석
12058정성태11/19/2019464디버깅 기술: 130. windbg - CoTaskMemFree/FreeCoTaskMem에서 발생한 덤프 분석 사례
1  2  3  4  5  [6]  7  8  9  10  11  12  13  14  15  ...