parent
1d1883f0e2
commit
bd9adbb637
|
@ -46,7 +46,8 @@ The <action> type attribute can be add,update,fix,remove.
|
|||
<body>
|
||||
|
||||
<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-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>
|
||||
|
|
|
@ -684,6 +684,50 @@ public class FastDatePrinter implements DatePrinter, Serializable {
|
|||
* @param value the value to append digits from.
|
||||
*/
|
||||
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
|
||||
char[] work = new char[MAX_DIGITS];
|
||||
int digit = 0;
|
||||
|
@ -703,6 +747,7 @@ public class FastDatePrinter implements DatePrinter, Serializable {
|
|||
buffer.append(work[digit]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Rules
|
||||
//-----------------------------------------------------------------------
|
||||
|
|
Loading…
Reference in New Issue