utf_16_writer.java

来自「This is a resource based on j2me embedde」· Java 代码 · 共 99 行

JAVA
99
字号
/* *    * * Copyright  1990-2007 Sun Microsystems, Inc. All Rights Reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER *  * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License version * 2 only, as published by the Free Software Foundation. *  * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * General Public License version 2 for more details (a copy is * included at /legal/license.txt). *  * You should have received a copy of the GNU General Public License * version 2 along with this work; if not, write to the Free Software * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA * 02110-1301 USA *  * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa * Clara, CA 95054 or visit www.sun.com if you need additional * information or have any questions. */package com.sun.cldc.i18n.j2me;import java.io.Writer;import java.io.OutputStream;import java.io.UnsupportedEncodingException;import java.io.IOException;/** * Writer for UTF-16 encoded output streams (default byte order). * We assume that character strings * are correctly converted to UFT-16, so no additional checking is performed. */ /* IMPL_NOTE: we need this class name because it is a part of * an internal interface: encoding name is converted into a class name, * and then Class.forName() is performed. */public class UTF_16_Writer extends UTF_16BE_Writer {    // Just extending the right class for the default byte order    // To change the default encoding you need to change the base class    /**     * Gets set to true after writing byte order mark (BOM), BOM is 0xfeff.     */    protected boolean addedBOM;    static final char[] bom = new char[] {0xfeff};    /**     * Write a portion of an array of characters.     *     * @param  cbuf  Array of characters     * @param  off   Offset from which to start writing characters     * @param  len   Number of characters to write     *     * @exception  java.io.IOException  If an I/O error occurs     */    public void write(char cbuf[], int off, int len) throws IOException {        if (!addedBOM) {            super.write(bom,0,1);            addedBOM=true;        }        super.write(cbuf,off,len);    }    /**     * Get the size in bytes of an array of chars.     *     * @param      array  Source buffer     * @param      offset Offset at which to start counting character sizes     * @param      length number of bytes to use for counting     *     * @return     number of bytes that the characters would be converted to     */    /* The class Helper will ask the writer for the size the output will be.     * Since chars already are in utf16, calculation is simple. */    public int sizeOf(char[] array, int offset, int length) {        // add the size of BOM        return super.sizeOf(array,offset,length) + 2;    }    /**     * Open the writer     */    public Writer open(OutputStream out, String enc)        throws UnsupportedEncodingException {        super.open(out,enc);        addedBOM = false;        return this;    }}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?