1
0
mirror of https://github.com/octoleo/plantuml.git synced 2024-12-31 22:11:53 +00:00

Merge pull request #809 from larrydiamond/master

Improve performance by replacing StringBuffer with StringBuilder
This commit is contained in:
PlantUML 2021-12-01 00:08:05 +01:00 committed by GitHub
commit 98ad31505c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
14 changed files with 15 additions and 15 deletions

View File

@ -96,7 +96,7 @@ public class Toolkit
{ {
boolean lDoCap = false; boolean lDoCap = false;
final StringTokenizer lST = new StringTokenizer(pText, ".- ", true); final StringTokenizer lST = new StringTokenizer(pText, ".- ", true);
final StringBuffer lSB = new StringBuffer(50); final StringBuilder lSB = new StringBuilder(50);
while(lST.hasMoreTokens()) while(lST.hasMoreTokens())
{ {
String lWord = lST.nextToken(); String lWord = lST.nextToken();

View File

@ -53,7 +53,7 @@ public class ResultPoint {
} }
public String toString() { public String toString() {
StringBuffer result = new StringBuffer(25); StringBuilder result = new StringBuilder(25);
result.append('('); result.append('(');
result.append(x); result.append(x);
result.append(','); result.append(',');

View File

@ -234,7 +234,7 @@ public final class BitArray {
} }
public String toString() { public String toString() {
StringBuffer result = new StringBuffer(size); StringBuilder result = new StringBuilder(size);
for (int i = 0; i < size; i++) { for (int i = 0; i < size; i++) {
if ((i & 0x07) == 0) { if ((i & 0x07) == 0) {
result.append(' '); result.append(' ');

View File

@ -213,7 +213,7 @@ public final class BitMatrix {
} }
public String toString() { public String toString() {
StringBuffer result = new StringBuffer(height * (width + 1)); StringBuilder result = new StringBuilder(height * (width + 1));
for (int y = 0; y < height; y++) { for (int y = 0; y < height; y++) {
for (int x = 0; x < width; x++) { for (int x = 0; x < width; x++) {
result.append(get(x, y) ? "X " : " "); result.append(get(x, y) ? "X " : " ");

View File

@ -224,7 +224,7 @@ final class GF256Poly {
} }
public String toString() { public String toString() {
StringBuffer result = new StringBuffer(8 * getDegree()); StringBuilder result = new StringBuilder(8 * getDegree());
for (int degree = getDegree(); degree >= 0; degree--) { for (int degree = getDegree(); degree >= 0; degree--) {
int coefficient = getCoefficient(degree); int coefficient = getCoefficient(degree);
if (coefficient != 0) { if (coefficient != 0) {

View File

@ -74,7 +74,7 @@ public final class ByteMatrix {
} }
public String toString() { public String toString() {
StringBuffer result = new StringBuffer(2 * width * height + 2); StringBuilder result = new StringBuilder(2 * width * height + 2);
for (int y = 0; y < height; ++y) { for (int y = 0; y < height; ++y) {
for (int x = 0; x < width; ++x) { for (int x = 0; x < width; ++x) {
switch (bytes[y][x]) { switch (bytes[y][x]) {

View File

@ -140,7 +140,7 @@ public final class QRCode {
// Return debug String. // Return debug String.
public String toString() { public String toString() {
StringBuffer result = new StringBuffer(200); StringBuilder result = new StringBuilder(200);
result.append("<<\n"); result.append("<<\n");
result.append(" mode: "); result.append(" mode: ");
result.append(mode); result.append(mode);

View File

@ -468,7 +468,7 @@ public class StringUtils {
public static String manageUnicodeNotationUplus(String s) { public static String manageUnicodeNotationUplus(String s) {
final Pattern pattern = Pattern.compile("\\<U\\+([0-9a-fA-F]{4,5})\\>"); final Pattern pattern = Pattern.compile("\\<U\\+([0-9a-fA-F]{4,5})\\>");
final Matcher matcher = pattern.matcher(s); final Matcher matcher = pattern.matcher(s);
final StringBuffer result = new StringBuffer(); final StringBuffer result = new StringBuffer(); // Can't be switched to StringBuilder in order to support Java 8
while (matcher.find()) { while (matcher.find()) {
final String num = matcher.group(1); final String num = matcher.group(1);
final int value = Integer.parseInt(num, 16); final int value = Integer.parseInt(num, 16);
@ -482,7 +482,7 @@ public class StringUtils {
public static String manageAmpDiese(String s) { public static String manageAmpDiese(String s) {
final Pattern pattern = Pattern.compile("\\&#([0-9]+);"); final Pattern pattern = Pattern.compile("\\&#([0-9]+);");
final Matcher matcher = pattern.matcher(s); final Matcher matcher = pattern.matcher(s);
final StringBuffer result = new StringBuffer(); final StringBuffer result = new StringBuffer(); // Can't be switched to StringBuilder in order to support Java 8
while (matcher.find()) { while (matcher.find()) {
final String num = matcher.group(1); final String num = matcher.group(1);
final char c = (char) Integer.parseInt(num); final char c = (char) Integer.parseInt(num);

View File

@ -92,7 +92,7 @@ public class ComponentTextArrow extends AbstractComponentText implements ArrowCo
if (fileFormat == FileFormat.UTXT) { if (fileFormat == FileFormat.UTXT) {
final Pattern pattern = Pattern.compile("\\<b\\>([0-9]+)\\</b\\>"); final Pattern pattern = Pattern.compile("\\<b\\>([0-9]+)\\</b\\>");
final Matcher matcher = pattern.matcher(s); final Matcher matcher = pattern.matcher(s);
final StringBuffer result = new StringBuffer(); final StringBuffer result = new StringBuffer(); // Can't be switched to StringBuilder in order to support Java 8
while (matcher.find()) { while (matcher.find()) {
final String num = matcher.group(1); final String num = matcher.group(1);
final String replace = StringUtils.toInternalBoldNumber(num); final String replace = StringUtils.toInternalBoldNumber(num);

View File

@ -109,7 +109,7 @@ class LogoScanner {
public LogoToken getToken() { public LogoToken getToken() {
final LogoToken token = new LogoToken(); final LogoToken token = new LogoToken();
final StringBuffer lexeme = new StringBuffer(); final StringBuilder lexeme = new StringBuilder();
if (i >= sourceLength) { if (i >= sourceLength) {
token.kind = LogoToken.END_OF_INPUT; token.kind = LogoToken.END_OF_INPUT;

View File

@ -62,7 +62,7 @@ public class PreprocessorUtils {
final Pattern p = Pattern.compile("%(\\w+)%"); final Pattern p = Pattern.compile("%(\\w+)%");
final Matcher m = p.matcher(s); final Matcher m = p.matcher(s);
final StringBuffer sb = new StringBuffer(); final StringBuffer sb = new StringBuffer(); // Can't be switched to StringBuilder in order to support Java 8
while (m.find()) { while (m.find()) {
final String var = m.group(1); final String var = m.group(1);
final String value = getenv(var); final String value = getenv(var);

View File

@ -940,7 +940,7 @@ public class SvgGraphics {
private String formatTitle(String title) { private String formatTitle(String title) {
final Pattern p = Pattern.compile("\\<U\\+([0-9A-Fa-f]+)\\>"); final Pattern p = Pattern.compile("\\<U\\+([0-9A-Fa-f]+)\\>");
final Matcher m = p.matcher(title); final Matcher m = p.matcher(title);
final StringBuffer sb = new StringBuffer(); final StringBuffer sb = new StringBuffer(); // Can't be switched to StringBuilder in order to support Java 8
while (m.find()) { while (m.find()) {
final String num = m.group(1); final String num = m.group(1);
final char c = (char) Integer.parseInt(num, 16); final char c = (char) Integer.parseInt(num, 16);

View File

@ -80,7 +80,7 @@ public class Cypher {
public synchronized String cypher(String s) { public synchronized String cypher(String s) {
final Matcher m = p.matcher(s); final Matcher m = p.matcher(s);
final StringBuffer sb = new StringBuffer(); final StringBuffer sb = new StringBuffer(); // Can't be switched to StringBuilder in order to support Java 8
while (m.find()) { while (m.find()) {
final String word = m.group(0); final String word = m.group(0);
m.appendReplacement(sb, changeWord(word)); m.appendReplacement(sb, changeWord(word));

View File

@ -97,7 +97,7 @@ public class CellSet implements Iterable<TextGrid.Cell> {
} }
public String getCellsAsString(){ public String getCellsAsString(){
StringBuffer str = new StringBuffer(); StringBuilder str = new StringBuilder();
Iterator<TextGrid.Cell> it = iterator(); Iterator<TextGrid.Cell> it = iterator();
while(it.hasNext()){ while(it.hasNext()){
str.append(it.next().toString()); str.append(it.next().toString());