C 문자열을 Wstring으로 변환
C에서 문자열(또는 char)을 wstring(또는 wchar_t)으로 변환 )를 사용하면 일본어 한자와 같은 비ASCII 문자를 나타내는 데 사용되는 와이드 문자로 작업할 수 있습니다. 키릴 문자.
표준 라이브러리 사용
UTF-8과 UTF-16 간의 변환을 위해 표준 라이브러리는 다음과 같은 포괄적인 솔루션을 제공합니다.
#include <locale> #include <codecvt> #include <string> std::wstring_convert<std::codecvt_utf8_utf16<wchar_t>> converter; std::wstring wstr = converter.from_bytes("おはよう");
예제
다음 예 이 변환을 보여줍니다:
#include <iostream> int main() { std::string a = "Привет всем!"; std::wstring b = std::wstring_convert<std::codecvt_utf8_utf16<wchar_t>>().from_bytes(a); std::cout << b << std::endl; return 0; }
출력:
Привет всем!
레거시 접근 방식(더 이상 사용되지 않음)
codecvt 헤더는 C에서 더 이상 사용되지 않습니다. 17. 대체 라이브러리가 없는 시스템의 경우 레거시 라이브러리를 사용할 수 있습니다. 접근 방식:
#include <wchar.h> wchar_t* wcs = (wchar_t*)MultiByteToWideChar(CP_UTF8, 0, a.c_str(), -1, NULL, 0);
그러나 이 방법은 특정 유니코드 문자를 올바르게 처리하지 못할 수 있습니다.
위 내용은 C 문자열을 Wstring으로 변환하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!