A Classe StringBuilder em Java

Veja neste artigo como trabalhar com a classe StringBuilder na linguagem Java, muito utilizada na manipulação de objetos do tipo String, porém com mais flexibilidade e melhor desempenho.

Classe StringBuilder

A classe StringBuilder faz parte do pacote java.lang. Essa classe permite criar e manipular dados de Strings dinamicamente, ou seja, podem criar variáveis de String modificáveis.

O significado da classe StringBuilder não tem o mesmo sentido que classe String. Existe uma diferença entre essas classes, veja algumas características.

Características StringBuilder

Uma vantagem sobre a classe String é a concatenação de strings. Pois quando concatena strings com StringBuilder é invocado o método append. Esse método aloca novas strings concatenadas para o mesmo objeto, ou seja, cada vez que concatena strings não são criadas cópias dos objetos como é realizado pelo método concat da classe String, contribuindo para um melhor desempenho do sistema.

Listagem 1: Concatenação de Strings com método append.
public class TestaStringBuilder { public static void main(String[] args) { StringBuilder nomes = new StringBuilder(); nomes.append("Carlos>").append("Maria>").append("José>").append("Renata"); System.out.println(nomes.toString()); } }
Figura 1: Ilustração gráfica do código da Listagem 1.

Métodos StringBuilder

Abaixo são apresentados os métodos principais e mais utilizados.

getChars – Retorna o caractere especificado;

reverse – Retorna os caracteres invertidos;

Listagem 2: Métodos capacity, ensureCapacity, setLength e length.
public class Metodos_StringBuilder { public static void main(String[] args) { StringBuilder buffer = new StringBuilder("João Silveira Batista"); System.out.printf(" buffer = %s\n tamanho = %d\n capacidade (%d (tamanho) + " + "16(valor inicial padrão)) = %d\n\n", buffer.toString(),buffer.length(),buffer.length(),buffer.capacity()); //EXPANDE A CAPACIDADE P/ 75 CARACTERES buffer.ensureCapacity(75); System.out.printf("Nova Capacidade = %d\n\n", buffer.capacity()); //REDEFINE O TAMANHO, NÃO APARECENDO OS CARACTERES // SE O ARGUMENTO FOR MENOR QUE A QUANTIDADE DE CARACTERES ORIGINAL buffer.setLength(10); System.out.printf("Novo tamanho = %d\n buffer = %s\n",buffer.length(), buffer.toString()); } }
Listagem 3: Métodos charAt, setChar e reverse.
public class Metodos2_StringBuilder { public static void main(String[] args) { StringBuilder buffer = new StringBuilder("Usando outros métodos StringBuilder"); System.out.printf("buffer = %s\n", buffer.toString()); System.out.printf("Caractere index 0: %s\nCaractere index 4: " + "%s\n\n",buffer.charAt(0),buffer.charAt(4)); char[] charArray = new char[buffer.length()]; buffer.getChars(0, buffer.length(), charArray, 0); System.out.print("Os caracteres são: "); for(char c : charArray) System.out.print(c); buffer.setCharAt(0, 'O'); buffer.setCharAt(4, 'P'); System.out.printf("\n\nbuffer = %s", buffer.toString()); buffer.reverse(); System.out.printf("\n\nbuffer = %s\n", buffer.toString()); } }

Construtores StringBuilder

Nessa classe existem quatro tipos de construtores que são apresentados abaixo, lembrando que quando é declarado o construtor sem argumentos a capacidade inicial é identificada com 16 caracteres.

Listagem 4: Construtores.
public class Contrutores_StringBuilder { public static void main(String[] args) { StringBuilder buffer1 = new StringBuilder(); StringBuilder buffer2 = new StringBuilder(5655); StringBuilder buffer3 = new StringBuilder("Texto Qualquer"); System.out.printf("buffer1 = \"%s\"\n", buffer1.toString()); System.out.printf("buffer2 = \"%s\"\n", buffer2.toString()); System.out.printf("buffer3 = \"%s\"\n", buffer3.toString()); } }

Método insert

Os métodos insert sobrecarregados inserem valores de vários tipos (primitivos, arrays de caracteres, Strings, Objects e CharSequences) em qualquer posição de um StringBuilder.

Existem alguns cuidados nesses tipos de operação, pois se inserir um número maior que um comprimento da StringBuilder ou menor que 0, irá estourar uma exceção StringIndexOutBoundsException.

Listagem 5: Método insert.
public class StringBuilder_Insert { public static void main(String[] args) { Object objetoRef = "Maria"; String String = "Joaquina"; char[] conjArray = {'S','i','l','v','a'}; StringBuilder buffer = new StringBuilder(); buffer.insert(0, objetoRef); buffer.insert(0, " "); buffer.insert(0, String); buffer.insert(0, " "); buffer.insert(0, conjArray); buffer.insert(0, " "); System.out.printf("Valores:\n%s\n\n", buffer.toString()); } }

Método delete

Os métodos delete excluem caracteres em qualquer posição em um StringBuilder, aceitando 2 argumentos sendo que um deles é o índice inicial e o índice a mais do fim dos caracteres a excluir. O método deleteCharAt aceita um argumento que é o índice do caractere a excluir.

Listagem 6: Método delete.
public class StringBuilder_Delete { public static void main(String[] args) { Object objetoRef = "Maria"; String String = "Joaquina"; char[] conjArray = {'S','i','l','v','a'}; StringBuilder buffer = new StringBuilder(); buffer.insert(0, objetoRef); buffer.insert(0, " "); buffer.insert(0, String); buffer.insert(0, " "); buffer.insert(0, conjArray); buffer.insert(0, " "); System.out.printf("Valores antes do delete:\n%s\n\n", buffer.toString()); buffer.delete(0, 2); buffer.deleteCharAt(4); System.out.printf("Valores depois do delete:\n%s\n\n", buffer.toString()); } }

Para saber mais dos métodos acesse.

Artigos relacionados