The getChars(int srcBegin, int srcEnd, char[] dst, int dstBegin) method of StringBuilder class copies the characters starting at the given index:srcBegin to index:srcEnd-1 from String contained by StringBuilder into an array of char passed as parameter to function.
- The characters are copied from StringBuilder into the array dst[] starting at index:dstBegin and ending at index:dstbegin + (srcEnd-srcBegin) – 1.
- The first character to be copied from StringBuilder to array is at index srcBegin and the last character to be copied is at index srcEnd-1.
- The total number of characters to be copied is equal to srcEnd-srcBegin.
Syntax:
public void getChars(int srcBegin, int srcEnd, char[] dst, int dstBegin)
Parameters: This method accepts four different parameters:
- srcBegin: represents index on which we have to start copying.
- srcEnd: represents index on which we have to stop copying.
- dst: represents the array to copy the data into.
- dstBegin: represents index of dest array we start pasting the copied data.
Return Value: This method does not return anything.
Exception: This method throws StringIndexOutOfBoundsException if:
- srcBegin < 0
- dstBegin < 0
- srcBegin > srcEnd
- srcEnd > this.length()
- dstBegin+srcEnd-srcBegin > dst.length
Below programs demonstrate the getChars() method of StringBuilder Class:
Example 1:
// Java program to demonstrate // the getChars() Method. class GFG { public static void main(String[] args) { // create a StringBuilder object // with a String pass as parameter StringBuilder str = new StringBuilder( "WelcomeGeeks" ); // print string System.out.println( "String = " + str.toString()); // create a char Array char [] array = new char [ 7 ]; // get char from index 0 to 7 // and store in array start index 0 str.getChars( 0 , 7 , array, 0 ); // print char array after operation System.out.print( "Char array contains : " ); for ( int i = 0 ; i < array.length; i++) { System.out.print(array[i] + " " ); } } } |
String = WelcomeGeeks Char array contains : W e l c o m e
Example 2:
// Java program to demonstrate // the getChars() Method. import java.util.*; class GFG { public static void main(String[] args) { // create a StringBuilder object // with a String pass as parameter StringBuilder str = new StringBuilder( "evil dead_01" ); // print string System.out.println( "String = " + str.toString()); // create a char Array char [] array = new char [ 10 ]; // initialize all character to _(underscore). Arrays.fill(array, '_' ); // get char from index 5 to 9 // and store in array start index 3 str.getChars( 5 , 9 , array, 3 ); // print char array after operation System.out.print( "char array contains : " ); for ( int i = 0 ; i < array.length; i++) { System.out.print(array[i] + " " ); } } } |
String = evil dead_01 char array contains : _ _ _ d e a d _ _ _
Example 3: To demonstrate StringIndexOutOfBoundException
// Java program to demonstrate // exception thrown by the getChars() Method. import java.util.*; class GFG { public static void main(String[] args) { // create a StringBuilder object // with a String pass as parameter StringBuilder str = new StringBuilder( "evil dead_01" ); // create a char Array char [] array = new char [ 10 ]; // initialize all character to _(underscore). Arrays.fill(array, '_' ); try { // if start is greater then end str.getChars( 5 , 2 , array, 0 ); } catch (Exception e) { System.out.println( "Exception: " + e); } } } |
Exception: java.lang.StringIndexOutOfBoundsException: srcBegin > srcEnd