在java筆試題中,java字符串算法筆試題是不可缺少的一部分,長沙達內(nèi)教育java培訓機構(gòu)的小編整理了一份java字符串算法筆試題及答案,希望對大家能夠有所幫助。
1、什么是String,它是什么數(shù)據(jù)類型?
答:String是定義在java.lang包下的一個類,它不是基本數(shù)據(jù)類型。
String是不可變的,JWM使用字符串池來儲存所有的字符串對象。
2、創(chuàng)建String對象的不同方式有哪些?
答:兩種方式。
一種是通過new很關(guān)鍵字來創(chuàng)建。使用這種方式時,JWM創(chuàng)建字符串對象但不存儲在字符串池中,我們可以調(diào)用intern()方法將該字符串對象存儲在字符串池中,如果該字符串池已經(jīng)有了同樣值得字符串,則返回引用。
另一種是使用雙引號來直接創(chuàng)建。使用這種方式時。JVM去字符串找有么有相同值得字符串,如果有,則返回找到的字符串引用。否則創(chuàng)建一個新的字符串對象,并·存儲在字符串池中。
例如:
String?str=new?String("abc");String?str1="abc";
3、寫一個方法來判斷一個String是否是回文(順讀和倒讀都一樣的詞)?
答:String類中并沒有提供翻轉(zhuǎn)方法供我們使用,但StringBuffer和StringBuilder有reverse方法。
private?static?boolen?isPalindrome(String?str){ if(str==null){ return?false; } StringBuilder?strBuilder=new?StringBuilder(str); srtBuilder.reverse(); return?strBuilder.toString().equals(str);}
不使用reverse方法實現(xiàn)
private?static?boolean?isPalindromeString(String?str){ if(str==null) return?null; int?length=str.length(); System.out.println(length/2); for(int?i=0;i<length/2;i++){ if(str.charAt(i)!=str.charAt(length-i-1)) return?false; } return?true;}
4、如何讓一個字符串變成小寫或大寫形式?
答:toUpperCase和toLowerCase方法
5、如何比較兩個字符串?
答:String內(nèi)部實現(xiàn)了Comparable接口,有兩個比較方法:compareTo(String anotherString)和compareToIgnoreCase(String str)。
compareTo(String anotherString)與傳入的anotherString字符串進行比較,如果小于傳入的字符串返回負數(shù),如果大于則返回正數(shù)。當兩個字符串值想等時,返回0此時equals方法會返回true。
equalsIgnoreCase(String str)該方法與compareTo方法類似,區(qū)別只是內(nèi)部利用了Character.toUpperCase等方法進行了大小轉(zhuǎn)換后進行比較。
6、如何將String轉(zhuǎn)換為char,反過來呢?
答:String是一系列字符,所以我們無法轉(zhuǎn)換成單一的char但是可以調(diào)用toCharArray()方法將字符串轉(zhuǎn)換成字符數(shù)組。
String?str="Java?interview"; //string?to?char?array; char[]?chars=str.toCharArray(); system.out.println(chars.length);
7、如何將String轉(zhuǎn)換為byte array,反過來呢?
答:使用String的getBytes()方法將String轉(zhuǎn)換成byte數(shù)組,使用String的構(gòu)造方法new String(byte[] arr)將byte數(shù)據(jù)轉(zhuǎn)為String。
public?class?StringToByteArray{ public?static?void?main(String[]?args){ String?str="PANKAJ"; byte[]?byteArr=str.getBytes(); //print?the?byte[]?elements System.out.println("String?to?byte?array:"+Array.toString(byteArr)) } public?static?void?main(String[]?args) { byte[]?byteArray={'P','A','N','k','A','J'}; byte[]?byteArray={80,65,78,75,65,74}; String?str=new?String(byteArray); Srting?str1=new?String(byteArray1); System.out.println(str); System.out.println(str1); }}
8、淺談一下String, StringBuffer,StringBuilder的區(qū)別?
答:String是不可變類,每當我們對String進行操作的時候,總會創(chuàng)建新的字符串。操作String和耗費資源,所以java提供了兩個工具類來操作String——StringBuffer和StringBuilder。
StringBuilder和StringBuffer是可變類,StringBuffer是線程安全的,StringBuilder則不是線程安全的。所以在多線程對同一字符串進行操作的時候,我們選擇StringBuffer。在不需要處理多線程的情況下,StringBuilder的效率比StringBuffer高。
9、String是不可變的有什么好處?
答:由于String是不可變類,所以在多線程中使用是安全的,我們不需要做其他任何同步操作。
String是不可變的,其值也是不可變的,所以用來存儲數(shù)據(jù)密碼很安全。
因為java字符串不可變,可以在java運行時節(jié)省大量堆空間。因為不同的字符串變量可以引用池中的相同的字符串。如果字符串是可變的話,任何一個變量的值改變,就會映射到其他變量,那么字符串池也就沒有什么意義了。
10、如何分割一個String?
答:public String[] split(String regex):
根據(jù)傳入的正則字符串進行分割,注意,如果最后一位剛好有傳入的字符,則返回的數(shù)組不會有空字符串。
String?s="abcada" System.out.println(Arrays.toString(s.split("a")); //以上代碼輸出結(jié)果為[,bc,,d]. public?String[]?split(String?regex,int?limit): //限制分割結(jié)果數(shù)組中有幾個字符串。傳入2,則結(jié)果分割后數(shù)組長度為2。 String?s="Y,Kunming,Yunnan"; String[]?data=s.split(",".2); System.out.println("Name=",data[0]);//Y System.out.println("Address=",data[1]);//Kunming,Yunnan //實際上第一個方法調(diào)用了第二個方法,只不過不限制返回的數(shù)組長度了 public?String[]?split(String?regex) { return?split(regex,0); }
11、如何判斷兩個String是否相等?
答:有兩種方式判斷字符串是否相等,使用“= = ”或者使用equals方法。當使用 “= =”操作符時,不僅比較字符串的值還比較引用的內(nèi)存的值。大多相互情況下,我們只需要判斷值是否相等,此時用equals方法即可。
還有一個用equalsIgnoreCase可以用來忽略大小寫進行比較。
String?s1="abc"; String?s2="abc" String?s3=new?String("abc"); System.out.println("s1?==?s2???"+(s1==s2));//true System.out.println("s1?==?s3???"+(s1==s3));//false System.out.println("s1?equals?s3???"+s1.equals(s3));//true
12、String的intern()方法
答:當intern()方法被調(diào)用,如果字符串池中已經(jīng)有一個字符串和當前調(diào)用方法的字符串equals相等,那么就會返回池中的字符串。如果池中沒有的話,則首先將當前字符串加入到池中,然后返回引用。
13、String是線程安全的嗎?
答:String是不可變量,一旦創(chuàng)建了String對象,我們就無法改變他的值,因此,它的線程是安全的,可以安全的用于多線程環(huán)境中。
14、為什么我們在使用HashMap的時候總是用String做key?
答:因為字符串是不可變的,當創(chuàng)建字符串的時候,他的hashcode被緩存下來,不需要再次計算。因為HashMap內(nèi)部實現(xiàn)是通過key的hashcode來確定value的存儲位置,所以相比于其他對象更快。這也就是為什么我們平時使用String作為HashMatp對象。
15、這里引入一個新的問題,了解String.intern()方法嗎?
String.intern()查找常量池中是否有相同的unicode字符串常量,如果有則返回其引用,如果沒有,則在常量池中增加一個unicode等于str的字符串并返回它的引用。因此在用String進行字符串拼接時,會產(chǎn)生很多臨時變量。建議多使用StringBuffer/StringBuilder。
16、String/StringBuffer/StringBuilder都分別存放在什么地方?
String是存放在常量池中,在編譯期間已經(jīng)被確定了。new String()不是字符串常量,他有自己的地址空間,放在堆空間,而其他兩個都存放在堆空間中。
以上就是長沙達內(nèi)教育java培訓機構(gòu)的小編針對“java字符串算法筆試題及答案”的內(nèi)容進行的回答,希望對大家有所幫助,如有疑問,請在線咨詢,有專業(yè)老師隨時為你服務(wù)。
Java筆試題