⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 digitlist.java

📁 java源代码 请看看啊 提点宝贵的意见
💻 JAVA
📖 第 1 页 / 共 2 页
字号:
/* * @(#)DigitList.java	1.28 03/01/23 * * Copyright 2003 Sun Microsystems, Inc. All rights reserved. * SUN PROPRIETARY/CONFIDENTIAL. Use is subject to license terms. *//* * (C) Copyright Taligent, Inc. 1996, 1997 - All Rights Reserved * (C) Copyright IBM Corp. 1996 - 1998 - All Rights Reserved * *   The original version of this source code and documentation is copyrighted * and owned by Taligent, Inc., a wholly-owned subsidiary of IBM. These * materials are provided under terms of a License Agreement between Taligent * and Sun. This technology is protected by multiple US and International * patents. This notice and attribution to Taligent may not be removed. *   Taligent is a registered trademark of Taligent, Inc. * */package java.text;/** * Digit List. Private to DecimalFormat. * Handles the transcoding * between numeric values and strings of characters.  Only handles * non-negative numbers.  The division of labor between DigitList and * DecimalFormat is that DigitList handles the radix 10 representation * issues; DecimalFormat handles the locale-specific issues such as * positive/negative, grouping, decimal point, currency, and so on. * * A DigitList is really a representation of a floating point value. * It may be an integer value; we assume that a double has sufficient * precision to represent all digits of a long. * * The DigitList representation consists of a string of characters, * which are the digits radix 10, from '0' to '9'.  It also has a radix * 10 exponent associated with it.  The value represented by a DigitList * object can be computed by mulitplying the fraction f, where 0 <= f < 1, * derived by placing all the digits of the list to the right of the * decimal point, by 10^exponent. * * @see  Locale * @see  Format * @see  NumberFormat * @see  DecimalFormat * @see  ChoiceFormat * @see  MessageFormat * @version      1.28 01/23/03 * @author       Mark Davis, Alan Liu */final class DigitList implements Cloneable {    /**     * The maximum number of significant digits in an IEEE 754 double, that     * is, in a Java double.  This must not be increased, or garbage digits     * will be generated, and should not be decreased, or accuracy will be lost.     */    public static final int MAX_COUNT = 19; // == Long.toString(Long.MAX_VALUE).length()    public static final int DBL_DIG = 17;    /**     * These data members are intentionally public and can be set directly.     *     * The value represented is given by placing the decimal point before     * digits[decimalAt].  If decimalAt is < 0, then leading zeros between     * the decimal point and the first nonzero digit are implied.  If decimalAt     * is > count, then trailing zeros between the digits[count-1] and the     * decimal point are implied.     *     * Equivalently, the represented value is given by f * 10^decimalAt.  Here     * f is a value 0.1 <= f < 1 arrived at by placing the digits in Digits to     * the right of the decimal.     *     * DigitList is normalized, so if it is non-zero, figits[0] is non-zero.  We     * don't allow denormalized numbers because our exponent is effectively of     * unlimited magnitude.  The count value contains the number of significant     * digits present in digits[].     *     * Zero is represented by any DigitList with count == 0 or with each digits[i]     * for all i <= count == '0'.     */    public int decimalAt = 0;    public int count = 0;    public char[] digits = new char[MAX_COUNT];    /**     * Return true if the represented number is zero.     */    boolean isZero()    {        for (int i=0; i<count; ++i) if (digits[i] != '0') return false;        return true;    }    /**     * Clears out the digits.     * Use before appending them.     * Typically, you set a series of digits with append, then at the point     * you hit the decimal point, you set myDigitList.decimalAt = myDigitList.count;     * then go on appending digits.     */    public void clear () {        decimalAt = 0;        count = 0;    }    /**     * Appends a digit to the list. Ignores all digits over MAX_COUNT,     * since they are not significant for either longs or doubles.     */    public void append(char digit) {        if (count < MAX_COUNT)            digits[count++] = digit;    }    /**     * Utility routine to get the value of the digit list     * If (count == 0) this throws a NumberFormatException, which     * mimics Long.parseLong().     */    public final double getDouble() {        if (count == 0) return 0.0;        StringBuffer temp = getStringBuffer();        temp.append('.').append(digits, 0, count);        temp.append('E');        temp.append(decimalAt);        return Double.parseDouble(temp.toString());    }    /**     * Utility routine to get the value of the digit list.     * If (count == 0) this returns 0, unlike Long.parseLong().     */    public final long getLong() {        // for now, simple implementation; later, do proper IEEE native stuff        if (count == 0) return 0;        // We have to check for this, because this is the one NEGATIVE value        // we represent.  If we tried to just pass the digits off to parseLong,        // we'd get a parse failure.        if (isLongMIN_VALUE()) return Long.MIN_VALUE;        StringBuffer temp = getStringBuffer();	temp.append(digits, 0, count);	for (int i = count; i < decimalAt; ++i) {	    temp.append('0');	}        return Long.parseLong(temp.toString());    }    /**     * Return true if the number represented by this object can fit into     * a long.     * @param isPositive true if this number should be regarded as positive     * @param ignoreNegativeZero true if -0 should be regarded as identical to     * +0; otherwise they are considered distinct     * @return true if this number fits into a Java long     */    boolean fitsIntoLong(boolean isPositive, boolean ignoreNegativeZero)    {        // Figure out if the result will fit in a long.  We have to        // first look for nonzero digits after the decimal point;        // then check the size.  If the digit count is 18 or less, then        // the value can definitely be represented as a long.  If it is 19        // then it may be too large.        // Trim trailing zeros.  This does not change the represented value.        while (count > 0 && digits[count - 1] == '0')	    --count;        if (count == 0) {            // Positive zero fits into a long, but negative zero can only            // be represented as a double. - bug 4162852            return isPositive || ignoreNegativeZero;        }        if (decimalAt < count || decimalAt > MAX_COUNT) return false;        if (decimalAt < MAX_COUNT) return true;        // At this point we have decimalAt == count, and count == MAX_COUNT.        // The number will overflow if it is larger than 9223372036854775807        // or smaller than -9223372036854775808.        for (int i=0; i<count; ++i)        {            char dig = digits[i], max = LONG_MIN_REP[i];            if (dig > max) return false;            if (dig < max) return true;        }        // At this point the first count digits match.  If decimalAt is less        // than count, then the remaining digits are zero, and we return true.        if (count < decimalAt) return true;        // Now we have a representation of Long.MIN_VALUE, without the leading        // negative sign.  If this represents a positive value, then it does        // not fit; otherwise it fits.        return !isPositive;    }    /**     * Set the digit list to a representation of the given double value.     * This method supports fixed-point notation.     * @param source Value to be converted; must not be Inf, -Inf, Nan,     * or a value <= 0.     * @param maximumFractionDigits The most fractional digits which should     * be converted.     */    public final void set(double source, int maximumFractionDigits)    {        set(source, maximumFractionDigits, true);    }    /**     * Set the digit list to a representation of the given double value.     * This method supports both fixed-point and exponential notation.     * @param source Value to be converted; must not be Inf, -Inf, Nan,     * or a value <= 0.     * @param maximumDigits The most fractional or total digits which should     * be converted.     * @param fixedPoint If true, then maximumDigits is the maximum     * fractional digits to be converted.  If false, total digits.     */    final void set(double source, int maximumDigits, boolean fixedPoint)    {        if (source == 0) source = 0;        // Generate a representation of the form DDDDD, DDDDD.DDDDD, or        // DDDDDE+/-DDDDD.        char[] rep = Double.toString(source).toCharArray();        decimalAt = -1;        count = 0;        int exponent = 0;        // Number of zeros between decimal point and first non-zero digit after        // decimal point, for numbers < 1.        int leadingZerosAfterDecimal = 0;        boolean nonZeroDigitSeen = false;        for (int i = 0; i < rep.length; ) {            char c = rep[i++];            if (c == '.') {		decimalAt = count;            } else if (c == 'e' || c == 'E') {		exponent = parseInt(rep, i);		break;            } else if (count < MAX_COUNT) {		if (!nonZeroDigitSeen) {		    nonZeroDigitSeen = (c != '0');		    if (!nonZeroDigitSeen && decimalAt != -1)			++leadingZerosAfterDecimal;		}		if (nonZeroDigitSeen)		    digits[count++] = c;            }        }        if (decimalAt == -1)	    decimalAt = count;        if (nonZeroDigitSeen) {            decimalAt += exponent - leadingZerosAfterDecimal;        }        if (fixedPoint)        {            // The negative of the exponent represents the number of leading            // zeros between the decimal and the first non-zero digit, for            // a value < 0.1 (e.g., for 0.00123, -decimalAt == 2).  If this

⌨️ 快捷键说明

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