자바로 6년 가까이 벌어먹고 살면서도 자바가 내부적으로 인코딩을 어떻게 처리하는지 몰랐네요.
한글 위키피디어인 http://ko.wikipedia.org/wiki/UTF-8 에서는. 다음처럼 설명하고 있구요.
영문페이지인 http://en.wikipedia.org/wiki/UTF-8 에서는.. 다음처럼 설명하고 있습니다.자바는 내부적으로 문자열을 UTF-16 인코딩으로 저장하며, 문자열 직렬화를 위하여 UTF-8을 변형하여 사용하고 있다. 이를 변형된 UTF-8이라 부른다.
표준 UTF-8과의 차이는 크게 두 가지로, 한 가지는 U+0000을 1바이트가 아니라 2바이트, 즉 11000000 10000000으로 표현하는 것이다. 따라서 수정된 UTF-8에서는 인코딩된 문자열에 널 문자가 나타나지 않게 되며, 따라서 널 문자를 문자열의 끝으로 사용하는 C와 같은 언어에서 처리할 때 문자열이 잘리는 것을 막을 수 있다.
다른 한 가지 차이는 BMP 바깥의 문자를 인코딩하는 방법이다. 표준 UTF-8에서는 이 문자들은 위와 같이 4바이트로 인코딩되지만, 수정된 UTF-8에서는 이 문자들을 surrogate pair로 표시하여 두 문자로 나눈 뒤 같은 방법으로 인코딩한다. (이는 CESU-8과 동일하다) 이러한 방법은 자바의 문자 형이 16비트 크기이며, 따라서 U+10000 이상의 영역에 속한 유니코드 문자는 항상 두 개의 자바 문자로 표현되어야 한다는 것에서 유래하였다. 하지만 이 방법은 BMP 바깥의 문자를 UTF-8보다 더 긴 6바이트로 인코딩해야 한다.
이러한 차이 때문에 이 인코딩은 UTF-8과 엄격하게 구별해야 하며, 자바에서 내부적인 처리에만 사용하도록 권장된다. 또한 UTF-8과는 달리 IANA에 정식으로 등록된 문자 인코딩이 아니므로 인터넷 상의 정보 교환을 위해 사용하지 않아야 한다.
어렵네요. 정리해야 겠습니다.The following implementations are slight differences from the UTF-8 specification. They are incompatible with the UTF-8 specification.
[edit] CESU-8
Many pieces of software added UTF-8 conversions for UCS-2 data and did not alter their UTF-8 conversion when UCS-2 was replaced with the surrogate-pair supporting UTF-16. The result is that each half of a UTF-16 surrogate pair is encoded as its own 3-byte UTF-8 encoding, resulting in 6 bytes rather than 4 for characters outside the Basic Multilingual Plane. Oracle databases use this, as well as Java and Tcl as described below, and probably a great deal of other Windows software where the programmers were unaware of the complexities of UTF-16. Although most usage is by accident, a supposed benefit is that this preserves UTF-16 binary sorting order when CESU-8 is binary sorted.
[edit] Modified UTF-8
In Modified UTF-8 the null character (U+0000) is encoded as 0xc0,0x80 rather than 0x00. (0xc0,0x80 is not valid UTF-8 because it is not the shortest possible representation.) This means that the encoding of an array of Unicode containing the null character will not have a null byte in it, and thus will not be truncated if processed in a language such as C using traditional ASCIIZ string functions.
All known Modified UTF-8 implementations also treat the surrogate pairs as in CESU-8.
In normal usage, the Java programming language supports standard UTF-8 when reading and writing strings through
InputStreamReader
andOutputStreamWriter
. However it usesmodified UTF-8
for object serialization, for the Java Native Interface, and for embedding constants in class files. Tcl also uses the same modified UTF-8 as Java for internal representation of Unicode data.
중요한 건 자바가 내부적으로 UTF-8 이 아닌 변형된 형태로 사용한다는 것이라고 볼수 있겠습니다.
이런 글에 .. 인코딩에 대해 명확하신 분이.. 덧글을 달아주시면 좋겠네요.
'자바' 카테고리의 다른 글
[ibatis] 개발자 가이드 업데이트 (0) | 2009.02.28 |
---|---|
[ibatis] 메일링리스트를 통해서 본 3.0 소식 (2) | 2009.02.15 |
[eclipse] 2008년 정리 (1) | 2009.01.16 |
[groovy] HTTPBuilder module 사용하기 (0) | 2009.01.11 |
[메모] 웹애플리케이션의 실제 경로 가져오기 (0) | 2009.01.08 |