디버깅을 해보면 유니코드가 저장이됩니다. 예를 들어 제가 배열에 NAe:장미란 하면 NAe: 는 정상적으로 메모리에 잡히나, 장미란은 아스키코드?유니코드?로 저장이 됩니다. 이럴경우 printf해봐도 출력이 안되더라구요. 이럴경우는 어떻게해야합니까
조금 상황 설명이 부족한것 같네요.
소스코드까지 주실 수 있으신가요?
현재 소스가... 학교 컴퓨터에 있어서요... 집에서는 다른 프로그램 짜보는것을 연습중입니다. 답변 감사드리고 즐밤하시길.
printf("%s" ,.... 로 하셨나요? 유니코드라면 문자열에 0 이 들어있어서 출력이 안될겁니다. hex값으로 출력을 해보세요
유니코드와는 상관없이 모든 C/C++의 String Literal에는 trailing 0가 붙습니다.
Utf16이상은 문자열 중간에 0이들어갑니다 Int를 char로 처리하면 당연히 생기는 문제지 문자열 끝 null과는 다릅니다
아. 제가 잘못 이해했군요 죄송합니다.
유니코드는 문자 인코딩 종류의 하나인데, 그걸로 생각한 게 아니라 그냥 MBCS에서 2바이트 문자를 유니코드라고 착각한 것으로 보입니다.
유니코드 문자열을 제대로 유니코드 함수로 출력하면 절대 저런 일은 없습니다. 물론 제대로 printf("%ws", ...);로 출력했다는 가정 하에서는요.
http://cafe.daum.net/codeinside
C/C++ 컴파일러는 소스 코드를 ASCII로 필요한 keyword 만을 처리합니다. "" 안에 한글을 넣으실 경우, 그 문자 데이터 값은 소스 파일의 인코딩을 따라갑니다.
그런데 터미널의 인코딩이 소스 파일의 인코딩과 같지 않은 경우, 터미널 상으로 printf를 했을 때 깨져 보일 수 있는 것이죠.
이런 상황은 보통 윈도우보단 리눅스에서 잦은데, 터미널에서는 UTF-8로 처리하는데 소스 파일이 ANSI(cp949; euc-kr)로 인코딩되어 있는 경우 이런 문제가 생깁니다.
UNICODE 관련해서. TCHAR 에 맞는 함수모음이 각각 있습니다. Windows API 책 보시면. UNICODE 사용에 대한 내용이 있습니다.
각기 다른 문자셋. 글자의 갯수를 바꾸려면. 이렇게 합니다.
SBCS MBCS WBCS 문자셋. 문자표http://blog.naver.com/karis87/220555068911http://blog.naver.com/acidc?Redirect=Log&logNo=220524680627 MultiByteToWideChar() WideCharToMultiByte()
EUC-KR UTF-8 인코딩 변환을 하려면. 이렇게 합니다.http://blog.naver.com/kangzzz80?Redirect=Log&logNo=100109191252 MultiByteToWideChar() WideCharToMultiByte()
UTF-8 and Unicode FAQ for Unix/Linuxhttp://www.cl.cam.ac.uk/~mgk25/unicode.html
유니코드http://terms.naver.com/entry.nhn?docId=2270340&cid=51173&categoryId=51173
ASCIIhttp://terms.naver.com/entry.nhn?docId=2270339&cid=51173&categoryId=51173&expCategoryId=51173
euc-kr 과 utf-8을 변환해주는 iconv() 라이브러리 함수도 있습니다.
---------------------------------------------------------------------------- 젊음'은 모든것을 가능하게 만든다.
매일 1억명이 사용하는 프로그램을 함께 만들어보고 싶습니다. 정규 근로 시간을 지키는. 야근 없는 회사와 거래합니다.
각 분야별. 좋은 책'이나 사이트' 블로그' 링크 소개 받습니다. shintx@naver.com
텍스트 포맷에 대한 자세한 정보
<code>
<blockcode>
<apache>
<applescript>
<autoconf>
<awk>
<bash>
<c>
<cpp>
<css>
<diff>
<drupal5>
<drupal6>
<gdb>
<html>
<html5>
<java>
<javascript>
<ldif>
<lua>
<make>
<mysql>
<perl>
<perl6>
<php>
<pgsql>
<proftpd>
<python>
<reg>
<spec>
<ruby>
<foo>
[foo]
조금 상황 설명이 부족한것 같네요.소스코드까지
조금 상황 설명이 부족한것 같네요.
소스코드까지 주실 수 있으신가요?
내일 올리겠습니다.
현재 소스가... 학교 컴퓨터에 있어서요...
집에서는 다른 프로그램 짜보는것을 연습중입니다.
답변 감사드리고 즐밤하시길.
유니코드는
printf("%s" ,.... 로 하셨나요? 유니코드라면 문자열에 0 이 들어있어서 출력이 안될겁니다.
hex값으로 출력을 해보세요
유니코드와는 상관없이 모든 C/C++의 String
유니코드와는 상관없이 모든 C/C++의 String Literal에는 trailing 0가 붙습니다.
Utf16이상은 문자열 중간에 0이들어갑니다 Int를
Utf16이상은 문자열 중간에 0이들어갑니다
Int를 char로 처리하면 당연히 생기는 문제지 문자열 끝 null과는 다릅니다
아. 제가 잘못 이해했군요
아. 제가 잘못 이해했군요 죄송합니다.
질문자 분께서 유니코드라는 용어를 오해했을 수도 있습니다.
유니코드는 문자 인코딩 종류의 하나인데,
그걸로 생각한 게 아니라 그냥 MBCS에서 2바이트 문자를 유니코드라고 착각한 것으로 보입니다.
유니코드 문자열을 제대로 유니코드 함수로 출력하면 절대 저런 일은 없습니다.
물론 제대로 printf("%ws", ...);로 출력했다는 가정 하에서는요.
http://cafe.daum.net/codeinside
음. 이건 간단합니다.
C/C++ 컴파일러는 소스 코드를 ASCII로 필요한 keyword 만을 처리합니다.
"" 안에 한글을 넣으실 경우, 그 문자 데이터 값은 소스 파일의 인코딩을 따라갑니다.
그런데 터미널의 인코딩이 소스 파일의 인코딩과 같지 않은 경우,
터미널 상으로 printf를 했을 때 깨져 보일 수 있는 것이죠.
이런 상황은 보통 윈도우보단 리눅스에서 잦은데,
터미널에서는 UTF-8로 처리하는데 소스 파일이 ANSI(cp949; euc-kr)로 인코딩되어 있는 경우
이런 문제가 생깁니다.
http://cafe.daum.net/codeinside
윈도우에서 UNICODE는 TCHAR 를 사용합니다.
UNICODE 관련해서. TCHAR 에 맞는 함수모음이 각각 있습니다.
Windows API 책 보시면. UNICODE 사용에 대한 내용이 있습니다.
각기 다른 문자셋. 글자의 갯수를 바꾸려면. 이렇게 합니다.
SBCS MBCS WBCS 문자셋. 문자표
http://blog.naver.com/karis87/220555068911
http://blog.naver.com/acidc?Redirect=Log&logNo=220524680627
MultiByteToWideChar()
WideCharToMultiByte()
EUC-KR UTF-8 인코딩 변환을 하려면. 이렇게 합니다.
http://blog.naver.com/kangzzz80?Redirect=Log&logNo=100109191252
MultiByteToWideChar()
WideCharToMultiByte()
UTF-8 and Unicode FAQ for Unix/Linux
http://www.cl.cam.ac.uk/~mgk25/unicode.html
유니코드
http://terms.naver.com/entry.nhn?docId=2270340&cid=51173&categoryId=51173
ASCII
http://terms.naver.com/entry.nhn?docId=2270339&cid=51173&categoryId=51173&expCategoryId=51173
euc-kr 과 utf-8을 변환해주는 iconv() 라이브러리 함수도 있습니다.
----------------------------------------------------------------------------
젊음'은 모든것을 가능하게 만든다.
매일 1억명이 사용하는 프로그램을 함께 만들어보고 싶습니다.
정규 근로 시간을 지키는. 야근 없는 회사와 거래합니다.
각 분야별. 좋은 책'이나 사이트' 블로그' 링크 소개 받습니다. shintx@naver.com
댓글 달기