e186. Converting Between Strings (Unicode) and Other Character Set Encodings
Many network protocols and files store their characters with a
byte-oriented character set such as ISO-8859-1 (ISO-Latin-1).
However, Java's native character encoding is Unicode.
This example demonstrates how to convert ISO-8859-1 encoded
bytes in a ByteBuffer to a string in a CharBuffer and visa versa.
Charset charset = Charset.forName("ISO-8859-1");
CharsetDecoder decoder = charset.newDecoder();
CharsetEncoder encoder = charset.newEncoder();
try {
ByteBuffer bbuf = encoder.encode(CharBuffer.wrap("a string"));
CharBuffer cbuf = decoder.decode(bbuf);
String s = cbuf.toString();
} catch (CharacterCodingException e) {
}
In the example above, the encoding and decoding methods created new
ByteBuffers into which to encode or decoding the data. Moreover,
the newly allocated ByteBuffers are non-direct
(e168 Determining If a ByteBuffer Is Direct). The encoder and decoder provide
methods that use a supplied ByteBuffer rather than create one.
Here's an example that uses these methods:
ByteBuffer bbuf = ByteBuffer.allocateDirect(1024);
CharBuffer cbuf = CharBuffer.allocate(1024);
encoder.encode(cbuf, bbuf, false);
bbuf.flip();
decoder.decode(bbuf, cbuf, false);
cbuf.flip();
Машинный перевод
e186. Преобразование Между Вереницами(Нитями) (Unicode) и Другие Зашифровывания Набора символов
Много протоколов сети и файлов хранят их характеры с a
ориентируемый на байт набор символов, типа ISO-8859-1 (ISO-Latin-1).
Однако, родное зашифровывание характера(знака) Явы - Unicode.
Этот пример демонстрирует, как преобразовать закодированный ISO-8859-1
байты в Битебаффере к веренице(нити) в CharBuffer и визе versa.
Charset charset = Charset.forName("ISO-8859-1");
CharsetDecoder decoder = charset.newDecoder();
CharsetEncoder encoder = charset.newEncoder();
try {
ByteBuffer bbuf = encoder.encode(CharBuffer.wrap("a string"));
CharBuffer cbuf = decoder.decode(bbuf);
String s = cbuf.toString();
} catch (CharacterCodingException e) {
}
В примере выше, зашифровывание и расшифровка методов создали новый
ByteBuffers, чтобы закодировать или расшифровка данных. Кроме того,
недавно ассигнованные(размещенные) ByteBuffers являются непрямыми
(e168 Определение, Если Битебаффер Является Прямым). Кодирующее устройство и декодер обеспечивают
методы, которые используют снабженного Битебаффера, а не создают тот.
Вот - пример, который использует эти методы:
ByteBuffer bbuf = ByteBuffer.allocateDirect(1024);
CharBuffer cbuf = CharBuffer.allocate(1024);
encoder.encode(cbuf, bbuf, false);
bbuf.flip();
decoder.decode(bbuf, cbuf, false);
cbuf.flip();
Оригинальная версия
e186. Converting Between Strings (Unicode) and Other Character Set Encodings
Many network protocols and files store their characters with a
byte-oriented character set such as ISO-8859-1 (ISO-Latin-1).
However, Java's native character encoding is Unicode.
This example demonstrates how to convert ISO-8859-1 encoded
bytes in a ByteBuffer to a string in a CharBuffer and visa versa.
Charset charset = Charset.forName("ISO-8859-1");
CharsetDecoder decoder = charset.newDecoder();
CharsetEncoder encoder = charset.newEncoder();
try {
ByteBuffer bbuf = encoder.encode(CharBuffer.wrap("a string"));
CharBuffer cbuf = decoder.decode(bbuf);
String s = cbuf.toString();
} catch (CharacterCodingException e) {
}
In the example above, the encoding and decoding methods created new
ByteBuffers into which to encode or decoding the data. Moreover,
the newly allocated ByteBuffers are non-direct
(e168 Determining If a ByteBuffer Is Direct). The encoder and decoder provide
methods that use a supplied ByteBuffer rather than create one.
Here's an example that uses these methods:
ByteBuffer bbuf = ByteBuffer.allocateDirect(1024);
CharBuffer cbuf = CharBuffer.allocate(1024);
encoder.encode(cbuf, bbuf, false);
bbuf.flip();
decoder.decode(bbuf, cbuf, false);
cbuf.flip();