wcstombs 로 변환시 뒷부분이 잘림
글쓴이: purewell / 작성시간: 화, 2003/04/08 - 2:33오후
char* Conv(char* szString, const wchar_t* wzString) { int nSize=wcslen(wszString)*2; char* pTemp=NULL; pTemp=new char[nSize]; if (pTemp==NULL) return NULL; wcstombs(pTemp, wzString, nSize); strcpy(szString, pTemp); delete [] pTemp; return szString; } int main(...) { ... wchar_t* wsMyString=L"My Name is 샘이"; char szMyString[256]; Conv(szMyString, wsMyString); cerr << "\"" << szMyString << "\"" << endl; ... }
Quote:
결과 :
"My Name is"
ㅡ_-);
RedHat8을 쓰고 있으며,
export LANG=ko_KR.eucKR 로 환경설정되어 있습니다.
Forums:
리턴값을 체크해 보았습니다.wcstombs() 가 -1을 리턴하네
리턴값을 체크해 보았습니다.
wcstombs() 가 -1을 리턴하네요.
errno는 84고, perror로 찍어보니
현재 locale로는 한글을 표현 할 수가 없는것 아닐까요? 뭔가 locale을 변경시켜야 할 것 같은데요...
우리 모두 리얼리스트가 되자. 그러나 가슴에 이룰 수 없는 꿈을 가지자
환경변수가 Setting되어 있다고 해서 wcstombs 가 제대로 작동
환경변수가 Setting되어 있다고 해서 wcstombs 가 제대로 작동하지 않습니다.
Process내에서 setlocale 을 불러 설정해야 합니다.
---
http://coolengineer.com
setlocale(LC_ALL, "EUC-KR"); 로 하면,한글
setlocale(LC_ALL, "EUC-KR"); 로 하면,
한글은 안 나오고, 버퍼에 표시되지 않는 문자열이 포함되고,
setlocale(LC_ALL, "ko_KR"); 로 하면,
ㅡ_-); 오류 뜨더군요.
_____________________________
언제나 맑고픈 샘이가...
http://purewell.biz
L"My Name is 샘이"이렇게 쓰면, 에초에 '샘이'는 wide
L"My Name is 샘이"
이렇게 쓰면, 에초에 '샘이'는 wide character 가 아니라
multi-byte character 로 들어가서 그런 것 같네요.
"My Name is 샘이" 이 문자열을 mbstowcs 로 전환한 뒤,
그것을 다시 wcstombs 로 전환하면 제대로 될 겁니다.
문자열에 포함된 문자들을 읽어보면 일단 원인을 알 수 있을 거구요.
결론적으로 L"My Name is 샘이"를 컴파일러가 제대로 wide
character 로 바꾸지 못한 게 원인입니다. 어떻게 해결하는 지는
모르겠구요.
Orion Project : http://orionids.org
wcslen 메소드는 글자 갯수를 리턴.
제가 해결한 방법인데요.. 이런방법도 있다고 알아두시면 될꺼 같습니다..
* 한,영 혼용은 wcslen 으로 얻어온 값 *2 하면 되긴 하는데.. wchar_t 이 한,영,특수문자 막 섞여있는경우 wcslen*2 로도 잘 컨트롤이 안되더군요..;;
** ex) (가나다) welcom 가나다 [hihi you vist( 100 ) ~~ ] 이런식?
int size = wcstombs( NULL, orig, 0 ); // 이렇게 사용하면 메모리 사이즈를 리턴해 줍니다.
char *conv = (char*) malloc( size + 1 ); // wcslen 대신에 얻어온 사이즈로 malloc
wcstombs( conv, orig, size + 1 ); // 변경...
댓글 달기