- 浏览: 328339 次
文章分类
- 全部博客 (116)
- Oracle (29)
- MySQL (2)
- Java (20)
- .NET (2)
- Javascript (4)
- Spring (6)
- Struts (6)
- Hibernate (16)
- JSP (6)
- Tomcat (1)
- Quartz (2)
- RCS (1)
- Translate (12)
- PL/SQL (5)
- Sqlplus (1)
- System (6)
- Linux (11)
- Ubuntu (9)
- Windows (10)
- Mac (2)
- Tools (8)
- Mercurial (1)
- Google Code (1)
- Subversion (1)
- Debian (2)
- Freemarker (6)
- Web (2)
- PHP (1)
- Nginx (1)
最新评论
-
sunday1207:
private Class getParameterizedT ...
java 中 BaseDao 在Hibernate中的用法 -
SkimSkim:
你这里的解压是把文件夹11下面的所有文件都放在ins这个文件夹 ...
ubuntu 在终端使用 sqlplus 连接远程数据库 -
as619864232:
漫步邃思 写道其实常用的就那么几个命令,大部分都用不到的是啊, ...
windows cmd 命令 -
漫步邃思:
其实常用的就那么几个命令,大部分都用不到的
windows cmd 命令
byte
, BigDecimal
, and Calendar
are
supported. Limited formatting customization(定制) for arbitrary(任意的) user types is provided through the Formattable
interface.
Formatters are not necessarily(必要的) safe for multithreaded access. Thread safety is optional(可选的) and is the responsibility(责任) of users of methods in this class.
Formatted printing for the Java language is heavily(大量的) inspired(灵感) by C's
printf
. Although the format strings are similar(类似) to C, some
customizations(自定义) have been made to accommodate(适应) the Java language and exploit(开发) some
of its features(特性). Also, Java formatting is more strict(严格的) than C's; for example, if
a conversion is incompatible(不兼容) with a flag, an exception will be thrown. In C
inapplicable(不适用的) flags are silently(默默的) ignored. The format strings are (因此) intended(有打算) to
be recognizable(可认识的) to C programmers but not necessarily(必要的) completely(完全的) compatible(兼容的) with
those in C.
Examples of expected usage:
StringBuilder sb = new StringBuilder(); // Send all output to the Appendable object sb Formatter formatter = new Formatter(sb, Locale.US); // Explicit(明确的) argument indices(目录) may be used to re-order output. formatter.format("%4$2s %3$2s %2$2s %1$2s", "a", "b", "c", "d") // -> " d c b a" // Optional(可选的) locale as the first argument can be used to get // locale-specific formatting of numbers. The precision(精度) and width can be // given to round and align the value. formatter.format(Locale.FRANCE, "e = %+10.4f", Math.E); // -> "e = +2,7183" // The '(' numeric flag may be used to format negative(负的) numbers with // parentheses(括号) rather than a minus sign. Group separators are // automatically inserted. formatter.format("Amount(总数) gained(增加) or lost(丢失) since last statement: $ %(,.2f", balanceDelta); // -> "Amount gained or lost since(因为) last statement: $ (6,217.58)"
Convenience methods for common formatting requests exist as(以...的形式) illustrated(例举) by the following invocations:
// Writes a formatted string to System.out. System.out.format("Local time: %tT", Calendar.getInstance()); // -> "Local time: 13:34:18" // Writes formatted output to System.err. System.err.printf("Unable to open file '%1$s': %2$s", fileName, exception.getMessage()); // -> "Unable to open file 'food': No such file or directory"
Like C's sprintf(3)
, Strings may be formatted using the static
method String.format
:
// Format a string containing a date. import java.util.Calendar; import java.util.GregorianCalendar; import static java.util.Calendar.*; Calendar c = new GregorianCalendar(1995, MAY, 23); String s = String.format("Duke's Birthday: %1$tm %1$te,%1$tY", c); // -> s == "Duke's Birthday: May 23, 1995"
Organization
This specification(规范) is divided into(被分成) two sections(部分). The first section, Summary, covers the basic formatting concepts(概念). This section(部分) is intended(打算) for users who want to get started quickly and are familiar(常见的) with formatted printing in other programming languages. The second section, Details, covers(包含) the specific(具体的) implementation details. It is intended for users who want more precise(精细的) specification(规范) of formatting behavior(行为).
Summary
This section is intended to provide a brief overview of formatting concepts. For precise behavioral details, refer to the Details section.
Format String Syntax
Every method which produces formatted output requires a format string
and an argument list. The format string is a String
which may
contain fixed text and one or more embedded format specifiers. Consider
the following example:
This format string is the first argument to theCalendar c = ...; String s = String.format("Duke's Birthday: %1$tm %1$te,%1$tY", c);
format
method. It contains three format specifiers
"%1$tm
", "%1$te
", and "%1$tY
" which
indicate how the arguments should be processed and where they should be inserted
in the text. The remaining portions of the format string are fixed text
including "Dukes Birthday: "
and any other spaces or punctuation.
The argument list consists of all arguments passed to the method after the
format string. In the above example, the argument list is of size one and
consists of the Calendar
object
c
.
- The format specifiers for general, character, and numeric types have the
following syntax:
%[argument_index$][flags][width][.precision]conversion
The optional argument_index is a decimal integer indicating the position of the argument in the argument list. The first argument is referenced by "
1$
", the second by "2$
", etc.The optional flags is a set of characters that modify the output format. The set of valid flags depends on the conversion.
The optional width is a non-negative decimal integer indicating the minimum number of characters to be written to the output.
The optional precision is a non-negative decimal integer usually used to restrict the number of characters. The specific behavior depends on the conversion.
The required conversion is a character indicating how the argument should be formatted. The set of valid conversions for a given argument depends on the argument's data type.
- The format specifiers for types which are used to represents dates and times
have the following syntax:
%[argument_index$][flags][width]conversion
The optional argument_index, flags and width are defined as above.
The required conversion is a two character sequence. The first character is
't'
or'T'
. The second character indicates the format to be used. These characters are similar to but not completely identical to those defined by GNUdate
and POSIXstrftime(3c)
. - The format specifiers which do not correspond to arguments have the
following syntax:
%[flags][width]conversion
The optional flags and width is defined as above.
The required conversion is a character indicating content to be inserted in the output.
Conversions
Conversions are divided into the following categories:
- General - may be applied to any argument type
-
Character - may be applied to basic types which represent Unicode
characters:
char
,Character
,byte
,Byte
,short
, andShort
. This conversion may also be applied to the typesint
andInteger
whenCharacter.isValidCodePoint(int)
returnstrue
-
Numeric
-
Integral - may be applied to Java integral types:
byte
,Byte
,short
,Short
,int
andInteger
,long
,Long
, andBigInteger
-
Floating Point - may be applied to Java floating-point types:
float
,Float
,double
,Double
, andBigDecimal
-
Integral - may be applied to Java integral types:
-
Date/Time - may be applied to Java types which are capable of
encoding a date or time:
long
,Long
,Calendar
, andDate
. -
Percent - produces a literal
'%'
('\u0025') - Line Separator - produces the platform-specific line separator
The following table summarizes the supported conversions. Conversions denoted
by an upper-case character (i.e. 'B'
, 'H'
,
'S'
, 'C'
, 'X'
, 'E'
,
'G'
, 'A'
, and 'T'
) are the same as those
for the corresponding lower-case conversion characters except that the result is
converted to upper case according to the rules of the prevailing Locale
. The result is
equivalent to the following invocation of String.toUpperCase()
out.toUpperCase()
'b' , 'B'
|
general | If the argument arg is null , then the result is
"false ". If arg is a boolean or Boolean , then the
result is the string returned by String.valueOf(arg) .
Otherwise, the result is "true".
|
'h' , 'H'
|
general | If the argument arg is null , then the result is
"null ". Otherwise, the result is obtained by invoking
Integer.toHexString(arg.hashCode()) .
|
's' , 'S'
|
general | If the argument arg is null , then the result is
"null ". If arg implements Formattable , then
arg.formatTo
is invoked. Otherwise, the result is obtained by invoking
arg.toString() .
|
'c' , 'C'
|
character | The result is a Unicode character |
'd'
|
integral | The result is formatted as a decimal integer |
'o'
|
integral | The result is formatted as an octal integer |
'x' , 'X'
|
integral | The result is formatted as a hexadecimal integer |
'e' , 'E'
|
floating point | The result is formatted as a decimal number in computerized scientific notation |
'f'
|
floating point | The result is formatted as a decimal number |
'g' , 'G'
|
floating point | The result is formatted using computerized scientific notation or decimal format, depending on the precision and the value after rounding. |
'a' , 'A'
|
floating point | The result is formatted as a hexadecimal floating-point number with a significand and an exponent |
't' , 'T'
|
date/time | Prefix for date and time conversion characters. See Date/Time Conversions. |
'%'
|
percent | The result is a literal '%' ('\u0025')
|
'n'
|
line separator | The result is the platform-specific line separator |
Any characters not explicitly defined as conversions are illegal and are reserved for future extensions.
Date/Time Conversions
The following date and time conversion suffix characters are defined for the
't'
and 'T'
conversions. The types are similar to but
not completely identical to those defined by GNU date
and POSIX
strftime(3c)
. Additional conversion types are provided to access
Java-specific functionality (e.g. 'L'
for milliseconds within the
second).
The following conversion characters are used for formatting times:
'H'
|
Hour of the day for the 24-hour clock, formatted as two digits with a
leading zero as necessary i.e. 00 - 23 .
|
'I'
|
Hour for the 12-hour clock, formatted as two digits with a leading zero as
necessary, i.e. 01 - 12 .
|
'k'
|
Hour of the day for the 24-hour clock, i.e. 0 - 23 .
|
'l'
|
Hour for the 12-hour clock, i.e. 1 - 12 .
|
'M'
|
Minute within the hour formatted as two digits with a leading zero as
necessary, i.e. 00 - 59 .
|
'S'
|
Seconds within the minute, formatted as two digits with a leading zero as
necessary, i.e. 00 - 60 ("60 " is a special value
required to support leap seconds).
|
'L'
|
Millisecond within the second formatted as three digits with leading zeros
as necessary, i.e. 000 - 999 .
|
'N'
|
Nanosecond within the second, formatted as nine digits with leading zeros as
necessary, i.e. 000000000 - 999999999 .
|
'p'
|
Locale-specific morning or
afternoon marker in lower case, e.g."am " or "pm ".
Use of the conversion prefix 'T' forces this output to upper case.
|
'z'
|
RFC 822 style numeric time
zone offset from GMT, e.g. -0800 . This value will be adjusted as
necessary for Daylight Saving Time. For long , Long , and Date the time zone used
is the default time
zone for this instance of the Java virtual machine.
|
'Z'
|
A string representing the abbreviation for the time zone. This value will be
adjusted as necessary for Daylight Saving Time. For long , Long , and Date the time zone used
is the default time
zone for this instance of the Java virtual machine. The Formatter's locale
will supersede the locale of the argument (if any).
|
's'
|
Seconds since the beginning of the epoch starting at 1 January 1970
00:00:00 UTC, i.e. Long.MIN_VALUE/1000 to
Long.MAX_VALUE/1000 .
|
'Q'
|
Milliseconds since the beginning of the epoch starting at 1 January 1970
00:00:00 UTC, i.e. Long.MIN_VALUE to
Long.MAX_VALUE . |
The following conversion characters are used for formatting dates:
'B'
|
Locale-specific full month
name, e.g. "January" , "February" .
|
'b'
|
Locale-specific abbreviated
month name, e.g. "Jan" , "Feb" .
|
'h'
|
Same as 'b' .
|
'A'
|
Locale-specific full name of the day of the
week, e.g. "Sunday" , "Monday"
|
'a'
|
Locale-specific short name of the day of the
week, e.g. "Sun" , "Mon"
|
'C'
|
Four-digit year divided by 100 , formatted as two digits with
leading zero as necessary, i.e. 00 - 99
|
'Y'
|
Year, formatted as at least four digits with leading zeros as necessary,
e.g. 0092 equals 92 CE for the Gregorian calendar.
|
'y'
|
Last two digits of the year, formatted with leading zeros as necessary, i.e.
00 - 99 .
|
'j'
|
Day of year, formatted as three digits with leading zeros as necessary, e.g.
001 - 366 for the Gregorian calendar.
|
'm'
|
Month, formatted as two digits with leading zeros as necessary, i.e.
01 - 13 .
|
'd'
|
Day of month, formatted as two digits with leading zeros as necessary, i.e.
01 - 31
|
'e'
|
Day of month, formatted as two digits, i.e. 1 - 31 .
|
The following conversion characters are used for formatting common date/time compositions.
'R'
|
Time formatted for the 24-hour clock as "%tH:%tM"
|
'T'
|
Time formatted for the 24-hour clock as "%tH:%tM:%tS" .
|
'r'
|
Time formatted for the 12-hour clock as "%tI:%tM:%tS %Tp" . The
location of the morning or afternoon marker ('%Tp' ) may be
locale-dependent.
|
'D'
|
Date formatted as "%tm/%td/%ty" .
|
'F'
|
ISO 8601 complete date
formatted as "%tY-%tm-%td" .
|
'c'
|
Date and time formatted as "%ta %tb %td %tT %tZ %tY" , e.g.
"Sun Jul 20 16:17:00 EDT 1969" . |
Any characters not explicitly defined as date/time conversion suffixes are illegal and are reserved for future extensions.
Flags
The following table summarizes the supported flags. y means the flag is supported for the indicated argument types.
'-' | y | y | y | y | y | The result will be left-justified. |
'#' | y1 | - | y3 | y | - | The result should use a conversion-dependent alternate form |
'+' | - | - | y4 | y | - | The result will always include a sign |
' ' | - | - | y4 | y | - | The result will include a leading space for positive values |
'0' | - | - | y | y | - | The result will be zero-padded |
',' | - | - | y2 | y5 | - | The result will include locale-specific grouping separators |
'(' | - | - | y4 | y5 | - | The result will enclose negative numbers in parentheses |
1 Depends on the definition of Formattable
.
2 For 'd'
conversion only.
3 For 'o'
, 'x'
, and 'X'
conversions only.
4 For 'd'
, 'o'
, 'x'
, and
'X'
conversions applied to BigInteger
or
'd'
applied to byte
, Byte
, short
,
Short
, int
and Integer
,
long
, and Long
.
5 For 'e'
, 'E'
, 'f'
,
'g'
, and 'G'
conversions only.
Any characters not explicitly defined as flags are illegal and are reserved for future extensions.
Width
The width is the minimum number of characters to be written to the output. For the line separator conversion, width is not applicable; if it is provided, an exception will be thrown.
Precision
For general argument types, the precision is the maximum number of characters to be written to the output.
For the floating-point conversions 'e'
, 'E'
, and
'f'
the precision is the number of digits after the decimal
separator. If the conversion is 'g'
or 'G'
, then the
precision is the total number of digits in the resulting magnitude after
rounding. If the conversion is 'a'
or 'A'
, then the
precision must not be specified.
For character, integral, and date/time argument types and the percent and line separator conversions, the precision is not applicable; if a precision is provided, an exception will be thrown.
Argument Index
The argument index is a decimal integer indicating the position of the
argument in the argument list. The first argument is referenced by
"1$
", the second by "2$
", etc.
Another way to reference arguments by position is to use the
'<'
('\u003c') flag, which causes the argument for the
previous format specifier to be re-used. For example, the following two
statements would produce identical strings:
Calendar c = ...; String s1 = String.format("Duke's Birthday: %1$tm %1$te,%1$tY", c); String s2 = String.format("Duke's Birthday: %1$tm %<te,%<tY", c);
Details
This section is intended to provide behavioral details for formatting, including conditions and exceptions, supported data types, localization, and interactions between flags, conversions, and data types. For an overview of formatting concepts, refer to the Summary
Any characters not explicitly defined as conversions, date/time conversion
suffixes, or flags are illegal and are reserved for future extensions. Use of
such a character in a format string will cause an UnknownFormatConversionException
or UnknownFormatFlagsException
to be thrown.
If the format specifier contains a width or precision with an invalid value
or which is otherwise unsupported, then a IllegalFormatWidthException
or IllegalFormatPrecisionException
respectively will be thrown.
If a format specifier contains a conversion character that is not applicable
to the corresponding argument, then an IllegalFormatConversionException
will be thrown.
All specified exceptions may be thrown by any of the format
methods of Formatter
as well as by any format
convenience methods such as String.format
and PrintStream.printf
.
Conversions denoted by an upper-case character (i.e. 'B'
,
'H'
, 'S'
, 'C'
, 'X'
,
'E'
, 'G'
, 'A'
, and 'T'
) are
the same as those for the corresponding lower-case conversion characters except
that the result is converted to upper case according to the rules of the
prevailing Locale
. The result is
equivalent to the following invocation of String.toUpperCase()
out.toUpperCase()
General
The following general conversions may be applied to any argument type:
'b'
|
'\u0062' | Produces either "true " or "false " as returned by
Boolean.toString(boolean) .
If the argument is If the |
'B'
|
'\u0042' | The upper-case variant of 'b' .
|
'h'
|
'\u0068' | Produces a string representing the hash code value of the object.
If the argument, arg is If the |
'H'
|
'\u0048' | The upper-case variant of 'h' .
|
's'
|
'\u0073' | Produces a string.
If the argument is If the |
'S'
|
'\u0053' | The upper-case variant of 's' . |
The following flags apply to general conversions:
'-'
|
'\u002d' | Left justifies the output. Spaces ('\u0020') will be added at the
end of the converted value as required to fill the minimum width of the field.
If the width is not provided, then a MissingFormatWidthException
will be thrown. If this flag is not given then the output will be
right-justified.
|
'#'
|
'\u0023' | Requires the output use an alternate form. The definition of the form is specified by the conversion. |
The width
is the minimum number of characters to be written to the output. If the length
of the converted value is less than the width then the output will be padded by
' ' ('\u0020') until the total number of characters equals
the width. The padding is on the left by default. If the '-'
flag
is given, then the padding will be on the right. If the width is not specified
then there is no minimum.
The precision is the maximum number of characters to be written to the
output. The precision is applied before the width, thus the output will be
truncated to precision
characters even if the width is greater than
the precision. If the precision is not specified then there is no explicit limit
on the number of characters.
Character
This conversion may be applied tochar
and Character
. It may
also be applied to the types byte
, Byte
, short
,
and Short
, int
and Integer
when Character.isValidCodePoint(int)
returns true
. If it returns false
then an IllegalFormatCodePointException
will be thrown.
'c'
|
'\u0063' | Formats the argument as a Unicode character as described in Unicode Character
Representation. This may be more than one 16-bit char in the
case where the argument represents a supplementary character.
If the |
'C'
|
'\u0043' | The upper-case variant of 'c' . |
The '-'
flag defined for General
conversions applies. If the '#'
flag is given, then a FormatFlagsConversionMismatchException
will be thrown.
The width is defined as for General conversions.
The precision is not applicable. If the precision is specified then an IllegalFormatPrecisionException
will be thrown.
Numeric
Numeric conversions are divided into the following categories:
Numeric types will be formatted according to the following algorithm:
After digits are obtained for the integer part, fractional part, and exponent (as appropriate for the data type), the following transformation is applied:
- Each digit character d in the string is replaced by a locale-specific
digit computed relative to the current locale's zero
digit z; that is d -
'0'
+ z. - If a decimal separator is present, a locale-specific decimal separator is substituted.
- If the
','
('\u002c') flag is given, then the locale-specific grouping separator is inserted by scanning the integer part of the string from least significant to most significant digits and inserting a separator at intervals defined by the locale's grouping size. - If the
'0'
flag is given, then the locale-specific zero digits are inserted after the sign character, if any, and before the first non-zero digit, until the length of the string is equal to the requested field width. - If the value is negative and the
'('
flag is given, then a'('
('\u0028') is prepended and a')'
('\u0029') is appended. - If the value is negative (or floating-point negative zero) and
'('
flag is not given, then a'-'
('\u002d') is prepended. - If the
'+'
flag is given and the value is positive or zero (or floating-point positive zero), then a'+'
('\u002b') will be prepended.
If the value is NaN or positive infinity the literal strings "NaN" or
"Infinity" respectively, will be output. If the value is negative infinity, then
the output will be "(Infinity)" if the '('
flag is given otherwise
the output will be "-Infinity". These values are not localized.
Byte, Short, Integer, and Long
The following conversions may be applied to byte
, Byte
, short
,
Short
, int
and Integer
,
long
, and Long
.
'd'
|
'\u0054' | Formats the argument as a decimal integer. The localization algorithm is applied.
If the If the |
'o'
|
'\u006f' | Formats the argument as an integer in base eight. No localization is
applied.
If x is negative then the result will be an unsigned value generated
by adding 2n to the value where If the If the If |
'x'
|
'\u0078' | Formats the argument as an integer in base sixteen. No localization is
applied.
If x is negative then the result will be an unsigned value generated
by adding 2n to the value where If the If the If |
'X'
|
'\u0058' | The upper-case variant of 'x' . The entire string representing
the number will be converted to upper
case including the 'x' (if any) and all hexadecimal digits
'a' - 'f' ('\u0061' - '\u0066').
|
If the conversion is 'o'
, 'x'
, or 'X'
and both the '#'
and the '0'
flags are given, then
result will contain the radix indicator ('0'
for octal and
"0x"
or "0X"
for hexadecimal), some number of zeros
(based on the width), and the value.
If the '-'
flag is not given, then the space padding will occur
before the sign.
The following flags apply to numeric integral conversions:
'+'
|
'\u002b' | Requires the output to include a positive sign for all positive numbers. If
this flag is not given then only negative values will include a sign.
If both the |
' ' | '\u0020' | Requires the output to include a single extra space ('\u0020') for
non-negative values.
If both the |
'0'
|
'\u0030' | Requires the output to be padded with leading zeros
to the minimum field width following any sign or radix indicator except when
converting NaN or infinity. If the width is not provided, then a MissingFormatWidthException
will be thrown.
If both the |
','
|
'\u002c' | Requires the output to include the locale-specific group separators as described in the "group" section of the localization algorithm. |
'('
|
'\u0028' | Requires the output to prepend a '(' ('\u0028') and
append a ')' ('\u0029') to negative values.
|
If no flags are given the default formatting is as follows:
- The output is right-justified within the
width
- Negative numbers begin with a
'-'
('\u002d') - Positive numbers and zero do not include a sign or extra leading space
- No grouping separators are included
The width
is the minimum number of characters to be written to the output. This includes
any signs, digits, grouping separators, radix indicator, and parentheses. If the
length of the converted value is less than the width then the output will be
padded by spaces ('\u0020') until the total number of characters equals
width. The padding is on the left by default. If '-'
flag is given
then the padding will be on the right. If width is not specified then there is
no minimum.
The precision is not applicable. If precision is specified then an IllegalFormatPrecisionException
will be thrown.
The following conversions may be applied to BigInteger
.
'd'
|
'\u0054' | Requires the output to be formatted as a decimal integer. The localization algorithm is applied.
If the |
'o'
|
'\u006f' | Requires the output to be formatted as an integer in base eight. No
localization is applied.
If x is negative then the result will be a signed value beginning with
If x is positive or zero and the If the If the If the |
'x'
|
'\u0078' | Requires the output to be formatted as an integer in base sixteen. No
localization is applied.
If x is negative then the result will be a signed value beginning with
If x is positive or zero and the If the If the If the |
'X'
|
'\u0058' | The upper-case variant of 'x' . The entire string representing
the number will be converted to upper
case including the 'x' (if any) and all hexadecimal digits
'a' - 'f' ('\u0061' - '\u0066').
|
If the conversion is 'o'
, 'x'
, or 'X'
and both the '#'
and the '0'
flags are given, then
result will contain the base indicator ('0'
for octal and
"0x"
or "0X"
for hexadecimal), some number of zeros
(based on the width), and the value.
If the '0'
flag is given and the value is negative, then the
zero padding will occur after the sign.
If the '-'
flag is not given, then the space padding will occur
before the sign.
All flags defined for Byte, Short, Integer, and Long apply. The default behavior when no flags are given is the same as for Byte, Short, Integer, and Long.
The specification of width is the same as defined for Byte, Short, Integer, and Long.
The precision is not applicable. If precision is specified then an IllegalFormatPrecisionException
will be thrown.
The following conversions may be applied to float
, Float
,
double
and Double
.
'e'
|
'\u0065' | Requires the output to be formatted using computerized scientific
notation. The localization algorithm is
applied.
The formatting of the magnitude m depends upon its value. If m is NaN or infinite, the literal strings "NaN" or "Infinity", respectively, will be output. These values are not localized. If m is positive-zero or negative-zero, then the exponent will be
Otherwise, the result is a string that represents the sign and magnitude (absolute value) of the argument. The formatting of the sign is described in the localization algorithm. The formatting of the magnitude m depends upon its value. Let n be the unique integer such that 10n <=
m < 10n+1; then let a be the mathematically
exact quotient of m and 10n so that 1 <= a
< 10. The magnitude is then represented as the integer part of a, as a
single decimal digit, followed by the decimal separator followed by decimal
digits representing the fractional part of a, followed by the exponent
symbol The number of digits in the result for the fractional part of m or
a is equal to the precision. If the precision is not specified then the
default value is If the |
'E'
|
'\u0045' | The upper-case variant of 'e' . The exponent symbol will be
'E' ('\u0045').
|
'g'
|
'\u0067' | Requires the output to be formatted in general scientific notation as
described below. The localization algorithm is
applied.
After rounding for the precision, the formatting of the resulting magnitude m depends on its value. If m is greater than or equal to 10-4 but less than 10precision then it is represented in decimal format. If m is less than 10-4 or greater than or equal to 10precision, then it is represented in computerized scientific notation. The total number of significant digits in m is equal to the precision.
If the precision is not specified, then the default value is If the |
'G'
|
'\u0047' | The upper-case variant of 'g' .
|
'f'
|
'\u0066' | Requires the output to be formatted using decimal format. The localization algorithm is applied.
The result is a string that represents the sign and magnitude (absolute value) of the argument. The formatting of the sign is described in the localization algorithm. The formatting of the magnitude m depends upon its value. If m NaN or infinite, the literal strings "NaN" or "Infinity", respectively, will be output. These values are not localized. The magnitude is formatted as the integer part of m, with no leading zeroes, followed by the decimal separator followed by one or more decimal digits representing the fractional part of m. The number of digits in the result for the fractional part of m or
a is equal to the precision. If the precision is not specified then the
default value is |
'a'
|
'\u0061' | Requires the output to be formatted in hexadecimal exponential form. No
localization is applied.
The result is a string that represents the sign and magnitude (absolute value) of the argument x. If x is negative or a negative-zero value then the result will begin
with If x is positive or a positive-zero value and the The formatting of the magnitude m depends upon its value.
If the |
'A'
|
'\u0041' | The upper-case variant of 'a' . The entire string representing
the number will be converted to upper case including the 'x'
('\u0078') and 'p' ('\u0070' and all hexadecimal
digits 'a' - 'f' ('\u0061' -
'\u0066'). |
All flags defined for Byte, Short, Integer, and Long apply.
If the '#'
flag is given, then the decimal separator will always
be present.
If no flags are given the default formatting is as follows:
- The output is right-justified within the
width
- Negative numbers begin with a
'-'
- Positive numbers and positive zero do not include a sign or extra leading space
- No grouping separators are included
- The decimal separator will only appear if a digit follows it
The width is the minimum number of characters to be written to
the output. This includes any signs, digits, grouping separators, decimal
separators, exponential symbol, radix indicator, parentheses, and strings
representing infinity and NaN as applicable. If the length of the converted
value is less than the width then the output will be padded by spaces
('\u0020') until the total number of characters equals width. The
padding is on the left by default. If the '-'
flag is given then
the padding will be on the right. If width is not specified then there is no
minimum.
If the conversion is 'e'
, 'E'
or
'f'
, then the precision is the number of digits after the decimal
separator. If the precision is not specified, then it is assumed to be
6
.
If the conversion is 'g'
or 'G'
, then the precision
is the total number of significant digits in the resulting magnitude after
rounding. If the precision is not specified, then the default value is
6
. If the precision is 0
, then it is taken to be
1
.
If the conversion is 'a'
or 'A'
, then the precision
is the number of hexadecimal digits after the decimal separator. If the
precision is not provided, then all of the digits as returned by Double.toHexString(double)
will be output.
The following conversions may be applied BigDecimal
.
'e'
|
'\u0065' | Requires the output to be formatted using computerized scientific
notation. The localization algorithm is
applied.
The formatting of the magnitude m depends upon its value. If m is positive-zero or negative-zero, then the exponent will be
Otherwise, the result is a string that represents the sign and magnitude (absolute value) of the argument. The formatting of the sign is described in the localization algorithm. The formatting of the magnitude m depends upon its value. Let n be the unique integer such that 10n <=
m < 10n+1; then let a be the mathematically
exact quotient of m and 10n so that 1 <= a
< 10. The magnitude is then represented as the integer part of a, as a
single decimal digit, followed by the decimal separator followed by decimal
digits representing the fractional part of a, followed by the exponent
symbol The number of digits in the result for the fractional part of m or
a is equal to the precision. If the precision is not specified then the
default value is If the |
'E'
|
'\u0045' | The upper-case variant of 'e' . The exponent symbol will be
'E' ('\u0045').
|
'g'
|
'\u0067' | Requires the output to be formatted in general scientific notation as
described below. The localization algorithm is
applied.
After rounding for the precision, the formatting of the resulting magnitude m depends on its value. If m is greater than or equal to 10-4 but less than 10precision then it is represented in decimal format. If m is less than 10-4 or greater than or equal to 10precision, then it is represented in computerized scientific notation. The total number of significant digits in m is equal to the precision.
If the precision is not specified, then the default value is If the |
'G'
|
'\u0047' | The upper-case variant of 'g' .
|
'f'
|
'\u0066' | Requires the output to be formatted using decimal format. The localization algorithm is applied.
The result is a string that represents the sign and magnitude (absolute value) of the argument. The formatting of the sign is described in the localization algorithm. The formatting of the magnitude m depends upon its value. The magnitude is formatted as the integer part of m, with no leading zeroes, followed by the decimal separator followed by one or more decimal digits representing the fractional part of m. The number of digits in the result for the fractional part of m or
a is equal to the precision. If the precision is not specified then the
default value is |
All flags defined for Byte, Short, Integer, and Long apply.
If the '#'
flag is given, then the decimal separator will always
be present.
The default behavior when no flags are given is the same as for Float and Double.
The specification of width and precision is the same as defined for Float and Double.
Date/Time
This conversion may be applied to long
, Long
, Calendar
, and Date
.
't'
|
'\u0074' | Prefix for date and time conversion characters. |
'T'
|
'\u0054' | The upper-case variant of 't' . |
The following date and time conversion character suffixes are defined for the
't'
and 'T'
conversions. The types are similar to but
not completely identical to those defined by GNU date
and POSIX
strftime(3c)
. Additional conversion types are provided to access
Java-specific functionality (e.g. 'L'
for milliseconds within the
second).
The following conversion characters are used for formatting times:
'H'
|
'\u0048' | Hour of the day for the 24-hour clock, formatted as two digits with a
leading zero as necessary i.e. 00 - 23 . 00 corresponds
to midnight.
|
'I'
|
'\u0049' | Hour for the 12-hour clock, formatted as two digits with a leading zero as
necessary, i.e. 01 - 12 . 01 corresponds to one o'clock
(either morning or afternoon).
|
'k'
|
'\u006b' | Hour of the day for the 24-hour clock, i.e. 0 - 23 .
0 corresponds to midnight.
|
'l'
|
'\u006c' | Hour for the 12-hour clock, i.e. 1 - 12 . 1
corresponds to one o'clock (either morning or afternoon).
|
'M'
|
'\u004d' | Minute within the hour formatted as two digits with a leading zero as
necessary, i.e. 00 - 59 .
|
'S'
|
'\u0053' | Seconds within the minute, formatted as two digits with a leading zero as
necessary, i.e. 00 - 60 ("60 " is a special value
required to support leap seconds).
|
'L'
|
'\u004c' | Millisecond within the second formatted as three digits with leading zeros
as necessary, i.e. 000 - 999 .
|
'N'
|
'\u004e' | Nanosecond within the second, formatted as nine digits with leading zeros as
necessary, i.e. 000000000 - 999999999 . The precision of this value
is limited by the resolution of the underlying operating system or hardware.
|
'p'
|
'\u0070' | Locale-specific morning or
afternoon marker in lower case, e.g."am " or "pm ".
Use of the conversion prefix 'T' forces this output to upper case.
(Note that 'p' produces lower-case output. This is different from
GNU date and POSIX strftime(3c) which produce
upper-case output.)
|
'z'
|
'\u007a' |
RFC 822 style numeric time
zone offset from GMT, e.g. -0800 . This value will be adjusted as
necessary for Daylight Saving Time. For long , Long , and Date the time zone used
is the default time
zone for this instance of the Java virtual machine.
|
'Z'
|
'\u005a' | A string representing the abbreviation for the time zone. This value will be
adjusted as necessary for Daylight Saving Time. For long , Long , and Date the time zone used
is the default time
zone for this instance of the Java virtual machine. The Formatter's locale
will supersede the locale of the argument (if any).
|
's'
|
'\u0073' | Seconds since the beginning of the epoch starting at 1 January 1970
00:00:00 UTC, i.e. Long.MIN_VALUE/1000 to
Long.MAX_VALUE/1000 .
|
'Q'
|
'\u004f' | Milliseconds since the beginning of the epoch starting at 1 January 1970
00:00:00 UTC, i.e. Long.MIN_VALUE to
Long.MAX_VALUE . The precision of this value is limited by the
resolution of the underlying operating system or hardware. |
The following conversion characters are used for formatting dates:
'B'
|
'\u0042' | Locale-specific full month
name, e.g. "January" , "February" .
|
'b'
|
'\u0062' | Locale-specific abbreviated
month name, e.g. "Jan" , "Feb" .
|
'h'
|
'\u0068' | Same as 'b' .
|
'A'
|
'\u0041' | Locale-specific full name of the day of the
week, e.g. "Sunday" , "Monday"
|
'a'
|
'\u0061' | Locale-specific short name of the day of the
week, e.g. "Sun" , "Mon"
|
'C'
|
'\u0043' | Four-digit year divided by 100 , formatted as two digits with
leading zero as necessary, i.e. 00 - 99
|
'Y'
|
'\u0059' | Year, formatted to at least four digits with leading zeros as necessary,
e.g. 0092 equals 92 CE for the Gregorian calendar.
|
'y'
|
'\u0079' | Last two digits of the year, formatted with leading zeros as necessary, i.e.
00 - 99 .
|
'j'
|
'\u006a' | Day of year, formatted as three digits with leading zeros as necessary, e.g.
001 - 366 for the Gregorian calendar. 001 corresponds
to the first day of the year.
|
'm'
|
'\u006d' | Month, formatted as two digits with leading zeros as necessary, i.e.
01 - 13 , where "01 " is the first month of the year and
("13 " is a special value required to support lunar calendars).
|
'd'
|
'\u0064' | Day of month, formatted as two digits with leading zeros as necessary, i.e.
01 - 31 , where "01 " is the first day of the month.
|
'e'
|
'\u0065' | Day of month, formatted as two digits, i.e. 1 - 31 where
"1 " is the first day of the month. |
The following conversion characters are used for formatting common date/time compositions.
'R'
|
'\u0052' | Time formatted for the 24-hour clock as "%tH:%tM"
|
'T'
|
'\u0054' | Time formatted for the 24-hour clock as "%tH:%tM:%tS" .
|
'r'
|
'\u0072' | Time formatted for the 12-hour clock as "%tI:%tM:%tS %Tp" . The
location of the morning or afternoon marker ('%Tp' ) may be
locale-dependent.
|
'D'
|
'\u0044' | Date formatted as "%tm/%td/%ty" .
|
'F'
|
'\u0046' |
ISO 8601 complete date
formatted as "%tY-%tm-%td" .
|
'c'
|
'\u0063' | Date and time formatted as "%ta %tb %td %tT %tZ %tY" , e.g.
"Sun Jul 20 16:17:00 EDT 1969" . |
The '-'
flag defined for General
conversions applies. If the '#'
flag is given, then a FormatFlagsConversionMismatchException
will be thrown.
The width is
the minimum number of characters to be written to the output. If the length of
the converted value is less than the width
then the output will be
padded by spaces ('\u0020') until the total number of characters equals
width. The padding is on the left by default. If the '-'
flag is
given then the padding will be on the right. If width is not specified then
there is no minimum.
The precision is not applicable. If the precision is specified then an IllegalFormatPrecisionException
will be thrown.
Percent
The conversion does not correspond to any argument.
'%'
|
The result is a literal '%' ('\u0025')
The width is
the minimum number of characters to be written to the output including the
The The precision is not applicable. If the precision is specified an |
Line Separator
The conversion does not correspond to any argument.
'n'
|
the platform-specific line separator as returned by System.getProperty("line.separator") .
|
Flags, width, and precision are not applicable. If any are provided an IllegalFormatFlagsException
,
IllegalFormatWidthException
,
and IllegalFormatPrecisionException
,
respectively will be thrown.
Argument Index
Format specifiers can reference arguments in three ways:
-
Explicit indexing is used when the format specifier contains an
argument index. The argument index is a decimal integer indicating the position
of the argument in the argument list. The first argument is referenced by
"
1$
", the second by "2$
", etc. An argument may be referenced more than once.For example:
formatter.format("%4$s %3$s %2$s %1$s %4$s %3$s %2$s %1$s", "a", "b", "c", "d") // -> "d c b a d c b a"
-
Relative indexing is used when the format specifier contains a
'<'
('\u003c') flag which causes the argument for the previous format specifier to be re-used. If there is no previous argument, then aMissingFormatArgumentException
is thrown.formatter.format("%s %s %<s %<s", "a", "b", "c", "d") // -> "a b b b" // "c" and "d" are ignored because they are not referenced
-
Ordinary indexing is used when the format specifier contains neither
an argument index nor a
'<'
flag. Each format specifier which uses ordinary indexing is assigned a sequential implicit index into argument list which is independent of the indices used by explicit or relative indexing.formatter.format("%s %s %s %s", "a", "b", "c", "d") // -> "a b c d"
It is possible to have a format string which uses all forms of indexing, for example:
formatter.format("%2$s %s %<s %s", "a", "b", "c", "d") // -> "b a a b" // "c" and "d" are ignored because they are not referenced
The maximum number of arguments is limited by the maximum dimension of a Java
array as defined by The Java™ Virtual Machine Specification. If the
argument index is does not correspond to an available argument, then a MissingFormatArgumentException
is thrown.
If there are more arguments than format specifiers, the extra arguments are ignored.
Unless otherwise specified, passing a null
argument to any
method or constructor in this class will cause a NullPointerException
to be thrown.
发表评论
-
JDK 对应数字版本号
2013-08-01 17:22 1412J2SE 7 = 51 (0x33 hex),J2SE 6.0 ... -
error 和 exception 之间的区别
2012-10-13 09:21 1124很多程序员不清楚error和exception之间的区别,这区 ... -
使用 Java 遍历二叉树
2012-10-03 20:09 1358在计算机科学中,二叉树是每个节点最多有两个子树的树结构 ... -
Spring 中事务的传播性
2012-09-17 20:46 986在 Spring 中一共定义了 ... -
J2EE 全面简介
2012-07-19 13:04 943刘湛 (jeru@163.net), 武汉 ... -
OpenSessionInViewFilter 的一些了解
2012-07-16 20:55 1051Spring 中的 OpenSessionInViewFil ... -
设计模式
2012-07-16 17:42 1074《设计模式》一书原先把设计模式分为创建型模式、结构型模式、行为 ... -
ServletContext 以及 ServletConfig 和 ServletContextListener 的一些理解
2012-07-15 00:12 1539当 Servlet 容器启动的时候,会读取 web.xml 中 ... -
Quartz 中的一些细节
2012-07-12 19:10 884JobDetail 中有一个 JobDataMap,而 Tri ... -
Hibernate 注册方言以及时间精度
2012-07-12 19:09 1295Oracle 10G 的 JDBC 驱动在 JAVA 中 ... -
Quartz Cron 表达式支持到七个域及实例
2012-07-12 19:07 1707名称 是否必须 允许值 特殊字符 秒 ... -
在 Linux 下安装 JDK 和设置 JAVA 环境变量
2012-07-08 16:16 1830I know lot of you starting o ... -
java 中 BaseDao 在Hibernate中的用法
2012-07-02 17:41 3311import java.lang.reflect. ... -
Struts2 中 default.properties 的解释
2012-05-19 13:30 1951### Struts default properties ... -
Struts2 中 web.xml 的翻译
2012-05-19 13:01 1182The web.xml web application ... -
hibernate 中 SQLFunctionTemplate 类的翻译
2012-05-13 13:34 1905org.hibernate.dialect.funct ... -
Hibernate 中 SQLFunction 类的翻译
2012-05-13 13:27 1237org.hibernate.dialect.funct ... -
Java Matcher 翻译
2012-05-11 19:09 1121java.util.regex Class Mat ... -
Java Pattern 翻译
2012-05-09 20:18 1171java.util.regex Class Pattern ... -
Java Method 翻译
2012-05-04 15:21 1116java.lang.reflect Class Met ...
相关推荐
`MessageFormat`会根据参数位置替换占位符,允许我们在翻译时保持语义不变。 Java程序国际化还包括日期和时间的格式化,这可以通过`java.time.format.DateTimeFormatter`类实现。例如: ```java DateTimeFormatter...
在Java编程语言中,生成时间是一项基础且重要的任务。这个实验“java实验生成时间”旨在帮助学生理解如何在Java中处理日期和时间。在本文中,我们将深入探讨Java中的日期和时间API,以及如何在实际编程中应用这些...
ANTLR通常用于构建语法分析器,它能读取、处理、执行或翻译结构化文本或二进制文件。结合CodeBuff的功能,可能意味着此版本的CodeBuff集成了ANTLR来解析和理解代码结构,从而实现更精确的格式化。 使用CodeBuff的...
1. **翻译阶段**:当Web容器接收到对JSP页面的请求时,会将JSP页面转换为一个对应的Java源文件(.java)。 2. **编译阶段**:这个Java源文件被编译成字节码(.class)。 3. **执行阶段**:字节码文件被执行,生成...
对于更复杂的本地化需求,如日期、时间或数字格式,Android提供了`java.text.SimpleDateFormat`和`java.util.NumberFormat`类来处理。例如,可以根据地区设置来格式化日期: ```java SimpleDateFormat formatter = ...
1. **翻译阶段**:服务器将JSP页面翻译成一个Servlet源码。 2. **编译阶段**:Servlet源码被编译成字节码(.class文件)。 3. **加载与初始化**:Servlet被加载并实例化,执行`init()`方法。 4. **服务阶段**:每当...
- **Java Code Formatter**:配置代码格式化规则。 - **Java Appearance Members Sort Order**:配置成员排序顺序。 - **Java Organize Import**:配置自动组织导入语句的规则。 #### 五、Refactor(重构)菜单 **...
2. 打开Eclipse,进入`Window` -> `Preferences` -> `Java` -> `Code Style` -> `Formatter`。 3. 在`Formatter`页面,点击`Import...`,选择`winit-code-format.xml`文件导入代码格式化规则。 4. 接着,进入`Code ...
DisplayTag支持多语言环境,通过`locale`属性可以设置当前页面的语言环境,标签库会自动处理翻译。可以提供一个资源文件来定义各种语言下的提示文本。 8. **导出功能** 用户可以通过点击DisplayTag提供的导出链接...
根据协议,用户不得修改、翻译或创建该作品的衍生品,也不能进行任何形式的再分发。 - **版权**: 手册中包含的所有内容(包括但不限于文字、图表等)均受国际版权法保护。用户不得去除任何版权声明或其他所有权声明...
Spring框架是Java开发中最常用的轻量级开源框架之一,它以其强大的依赖注入(Dependency Injection,简称DI)和面向切面编程(Aspect-Oriented Programming,简称AOP)能力而闻名。Spring Core是Spring框架的基础...
在这个场景中,"test_items" 可能是测试用例的集合,而 "different_languages" 表明这些测试用例覆盖了多种编程语言,如Python、Java、JavaScript等。 标签 "Python" 提供了一个关键线索,意味着我们的焦点在于...
翻译属性文件**:检查国际化属性文件。 - **7.14.5. 没有被注释掉的 Main 函数**:确认 Main 方法是否已被注释掉。 - **7.14.6. 大写的 L**:建议使用小写字母 `l` 而不是大写的 `L`。 - **7.14.7. 声明数组的风格*...
- `<formatter>`:定义报告的输出格式。 #### 六、在Eclipse中使用Checkstyle ##### 6.1 下载和安装 - **通过Eclipse Marketplace**:在Eclipse中搜索“Checkstyle”插件并安装。 - **手动安装**:下载Checkstyle...
Eclipse中文教程英文直接翻译过来的,适合有一定Eclipse基础的人阅读,如果没有Eclipse基础,可找到这本书的英文原版对照阅读。 0.环境说明........................................................................