utf-8에 대해서 질문입니다.
글쓴이: mai / 작성시간: 화, 2006/10/10 - 10:44오후
지금 윈도우에서 mingw로 프로그래밍을 하고 있고 나중에 리눅스에 옮길 생각입니다.
유니코드로 짜고 있어서 내부에서는 wide 캐릭터를 사용하고 있습니다만....
이것을 UTF-8로 바꾸는 법을 모르겠습니다.
Visual C의 경우는 WideCharToMultiByte()를 호출하면 되지만 리눅스에서는 어떻게 하는지 알고 싶습니다.
직접 만들어야 한다면 좋은 라이브러리가 없는지요?
가능하면 윈도우에서도 사용할 수 있는 멀티플렛폼 라이브러리로.....
Forums:
wcstombs : wide to
wcstombs : wide to multi
mbstowcs : multi to wide
이 함수를 이용하시면 됩니다.
그리고 로케일 설정이 필요하시면 setlocale 함수로 조정하시면 될겁니다.
-------------------------------------------------------------------------------
It's better to appear stupid and ask question than to be silent and remain stupid.
-------------------------------------------------------------------------------
It's better to appear stupid and ask question than to be silent and remain stupid.
iconv를 써도 됩니다.
iconv를 써도 됩니다. conversion character set으로 "WCHAR_T"를 쓰시면 됩니다.
--
C FAQ: http://www.eskimo.com/~scs/C-faq/top.html
Korean Ver: http://www.cinsk.org/cfaqs/
C FAQ: http://www.eskimo.com/~scs/C-faq/top.html
Korean Ver: http://cinsk.github.io/cfaqs/
답변 감사합니다.
답변 감사합니다. 추가로 질문이 있습니다.
wcstombs : wide to multi
mbstowcs : multi to wide
이 함수는 와이드캐릭터와 멀티바이트로만 전환이 되는 줄 알았는데 UTF-8로도 전환이 되는지요?
그리고 iconv으로 변환을 할려고 했는데 변환 후의 길이를 알 수가 없어서 버퍼가 부족한 경우가 생길 것 같은데 UTF-8의 경우 영어가 아닌 문자는 가변길이라 정확한 길이를 알기가 힘든데 이 경우는 어떻게 하나요?
iconv(3)는 주어진 소스
iconv(3)는 주어진 소스 버퍼의 char들을 타겟 버퍼로 바꿔 줍니다. 이 때, source나 target의 버퍼의 크기가 부족하다면 부족한 크기만큼 알려주기 때문에 다시 iconv(3)를 불러서 해결하면 됩니다.
자세한 것은 info page를 참고하기 바랍니다.
--
C FAQ: http://www.eskimo.com/~scs/C-faq/top.html
Korean Ver: http://www.cinsk.org/cfaqs/
C FAQ: http://www.eskimo.com/~scs/C-faq/top.html
Korean Ver: http://cinsk.github.io/cfaqs/
댓글 달기