parent
1d1883f0e2
commit
bd9adbb637
|
@ -46,7 +46,8 @@ The <action> type attribute can be add,update,fix,remove.
|
||||||
<body>
|
<body>
|
||||||
|
|
||||||
<release version="3.5" date="tba" description="tba">
|
<release version="3.5" date="tba" description="tba">
|
||||||
<action issue="LANG-1247" type="update" dev="chas" due-to="Benoit Wiart">FastDatePrinter generates extra Date objects</action>
|
<action issue="LANG-1248" type="fix" dev="chas" due-to="Benoit Wiart">FastDatePrinter Memory allocation regression</action>
|
||||||
|
<action issue="LANG-1247" type="fix" dev="chas" due-to="Benoit Wiart">FastDatePrinter generates extra Date objects</action>
|
||||||
<action issue="LANG-1018" type="fix" dev="pschumacher" due-to="Nick Manley">Fix precision loss on NumberUtils.createNumber(String)</action>
|
<action issue="LANG-1018" type="fix" dev="pschumacher" due-to="Nick Manley">Fix precision loss on NumberUtils.createNumber(String)</action>
|
||||||
<action issue="LANG-1229" type="update" dev="pschumacher" due-to="Ruslan Cheremin">HashCodeBuilder.append(Object,Object) is too big to be inlined, which prevents whole builder to be scalarized</action>
|
<action issue="LANG-1229" type="update" dev="pschumacher" due-to="Ruslan Cheremin">HashCodeBuilder.append(Object,Object) is too big to be inlined, which prevents whole builder to be scalarized</action>
|
||||||
<action issue="LANG-1085" type="add" dev="oheger" due-to="oheger / kinow">Add a circuit breaker implementation</action>
|
<action issue="LANG-1085" type="add" dev="oheger" due-to="oheger / kinow">Add a circuit breaker implementation</action>
|
||||||
|
|
|
@ -684,25 +684,70 @@ public class FastDatePrinter implements DatePrinter, Serializable {
|
||||||
* @param value the value to append digits from.
|
* @param value the value to append digits from.
|
||||||
*/
|
*/
|
||||||
private static void appendFullDigits(final Appendable buffer, int value, int minFieldWidth) throws IOException {
|
private static void appendFullDigits(final Appendable buffer, int value, int minFieldWidth) throws IOException {
|
||||||
|
// specialized paths for 1 to 4 digits -> avoid the memory allocation from the temporary work array
|
||||||
|
// see LANG-1248
|
||||||
|
if (value < 10000) {
|
||||||
|
// less memory allocation path works for four digits or less
|
||||||
|
|
||||||
|
int nDigits = 4;
|
||||||
|
if (value < 1000) {
|
||||||
|
--nDigits;
|
||||||
|
if (value < 100) {
|
||||||
|
--nDigits;
|
||||||
|
if (value < 10) {
|
||||||
|
--nDigits;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// left zero pad
|
||||||
|
for (int i = minFieldWidth - nDigits; i > 0; --i) {
|
||||||
|
buffer.append('0');
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (nDigits) {
|
||||||
|
case 4:
|
||||||
|
buffer.append((char) (value / 1000 + '0'));
|
||||||
|
value %= 1000;
|
||||||
|
case 3:
|
||||||
|
if (value >= 100) {
|
||||||
|
buffer.append((char) (value / 100 + '0'));
|
||||||
|
value %= 100;
|
||||||
|
} else {
|
||||||
|
buffer.append('0');
|
||||||
|
}
|
||||||
|
case 2:
|
||||||
|
if (value >= 10) {
|
||||||
|
buffer.append((char) (value / 10 + '0'));
|
||||||
|
value %= 10;
|
||||||
|
} else {
|
||||||
|
buffer.append('0');
|
||||||
|
}
|
||||||
|
case 1:
|
||||||
|
buffer.append((char) (value + '0'));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// more memory allocation path works for any digits
|
||||||
|
|
||||||
// build up decimal representation in reverse
|
// build up decimal representation in reverse
|
||||||
char[] work = new char[MAX_DIGITS];
|
char[] work = new char[MAX_DIGITS];
|
||||||
int digit = 0;
|
int digit = 0;
|
||||||
while(value!=0) {
|
while (value != 0) {
|
||||||
work[digit++] = (char)(value % 10 + '0');
|
work[digit++] = (char) (value % 10 + '0');
|
||||||
value = value / 10;
|
value = value / 10;
|
||||||
}
|
}
|
||||||
|
|
||||||
// pad with zeros
|
// pad with zeros
|
||||||
while(digit<minFieldWidth) {
|
while (digit < minFieldWidth) {
|
||||||
buffer.append('0');
|
buffer.append('0');
|
||||||
--minFieldWidth;
|
--minFieldWidth;
|
||||||
}
|
}
|
||||||
|
|
||||||
// reverse
|
// reverse
|
||||||
while(--digit>=0) {
|
while (--digit >= 0) {
|
||||||
buffer.append(work[digit]);
|
buffer.append(work[digit]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Rules
|
// Rules
|
||||||
//-----------------------------------------------------------------------
|
//-----------------------------------------------------------------------
|
||||||
|
|
Loading…
Reference in New Issue