Tässä osiossa keskustelemme mikä on merkkijonon enimmäiskoko Javassa.
Sisään Java , a merkkijono voidaan pitää merkkijonona, ja merkkijonoa kutsutaan merkkijonoksi. String-luokka edustaa merkkijonoja. Emme voi muuttaa merkkijonoa, kun se on luotu. Merkkijonoobjekteja ei voi jakaa, koska ne ovat muuttumaton . Harkitse esimerkiksi seuraavaa merkkijonoa:
kartta javassa
String str='javatpoint';
Yllä oleva merkkijono vastaa:
char ch[] = {'j', 'a', 'v', 'a', 't', 'p', 'o', 'i', 'n', 't'}; String str = new String(ch);
String-luokka tarjoaa pituus()-menetelmän, joka määrittää merkkijonon pituuden. Menetelmän syntaksi on seuraava:
public int length()
Metodi palauttaa merkkijonon pituuden. The langan pituus on yhtä suuri kuin luku Unicode-yksiköt merkkijonossa. Java-alusta käyttää UTF-16-esitystä char-taulukoissa (jokainen merkki vie kaksi tavua), String- ja StringBuffer-luokissa. Tässä esityksessä lisämerkit esitetään merkkiarvojen parina, joista ensimmäinen on korkeiden korvikkeiden alueelta (uD800-uDBFF), toinen matalan korvikealueen (uDC00-uDFFF).
Metodi palauttaa pituuden, joka on tyyppiä int. Joten merkkijonon enimmäiskoko on sama kuin kokonaislukutietotyypin alue. Metodin palauttama enimmäispituus on Kokonaisluku.MAX_VALUE.
Int:n koko Javassa on 4 tavua (sisältää signed bitin eli MSB:n). Kokonaislukutietotyypin alue on -231231-1 (-2147483648 - 2147483647). Muista, että emme voi käyttää negatiivisia arvoja indeksointiin. Indeksointi tehdään enimmäisalueen sisällä. Se tarkoittaa, että emme voi tallentaa 2147483648th merkki. Siksi merkkijonon enimmäispituus Javassa on 0 numeroon 2147483647 . Joten meillä voi olla teoriassa merkkijono, jonka pituus on 2 147 483 647 merkkiä.
Etsitään merkkijonon enimmäispituus Java-ohjelman avulla.
StringMaxSize.java
vikas divyakirti
import java.util.Arrays; public class StringMaxSize { public static void main(String args[]) { for (int i = 0; i <1000; i++) { try integer.max_value is a constant that stores the maximum possible value for any integer variable char[] array="new" char[integer.max_value - i]; assign specified data to each element arrays.fill(array, 'a'); creating constructor of string class and parses an into it str="new" string(array); determines print length system.out.println(str.length()); } catch (throwable e) returns detail message this throwable system.out.println(e.getmessage()); prints system.out.println('last: ' + (integer.max_value i)); i); < pre> <p> <strong>Output:</strong> </p> <img src="//techcodeview.com/img/java-tutorial/05/java-string-max-size.webp" alt="Java String Max Size"> <h4>Note: We have not shown the complete output because the output is too long to show.</h4> <p>In the above example, we have used a for loop that executes 1000 times. Inside the try block, we have created an array of <strong>Integer.MAX_VALUE-i</strong> . After that, we have invoked the fill() method of the Arrays class. It assigns the specified data type value to each element of the specified range of the specified array.</p> <p>Inside the catch block, we caught the exception (if any) thrown by the fill() method and the <strong>getMessage()</strong> method prints the message related to the exception.</p> <p>Each character takes two bytes because Java stores string as UTF-16 codes.</p> <p>Whether you are appending strings directly or using a StringBuilder (much better), you will occasionally need twice as much memory: one to store the existing string and one to store the new string/buffer when it needs to be expanded.</p> <p>If we try to insert the value beyond the limit upon doing so, the memory gets overflow and the value that we get will be negative. For example, consider the following program:</p> <p> <strong>StringSizeBeyondLimit.java</strong> </p> <pre> public class StringSizeBeyondLimit { public static void main(String[] arg) { try { System.out.println( 'Trying to initialize' + ' a n with value' + ' Integer.MAX_VALUE + 1'); // Try to store value Integer.MAX_VALUE + 1 int n = Integer.MAX_VALUE + 1; // Print the value of N System.out.println('n = ' + n); } catch(Exception e) { System.out.println(e); } } } </pre> <p> <strong>Output:</strong> </p> <pre> Trying to initialize n with value Integer.MAX_VALUE + 1 n = -2147483648 </pre> <hr></1000;>
Lähtö:
Trying to initialize n with value Integer.MAX_VALUE + 1 n = -2147483648
1000;>