1.JDK和JRE有什么區(qū)別?
JDK:JavaDevelopmentKit的簡(jiǎn)稱,java開發(fā)工具包,提供了java的開發(fā)環(huán)境和運(yùn)行環(huán)境。
JRE:JavaRuntimeEnvironment的簡(jiǎn)稱,java運(yùn)行環(huán)境,為java的運(yùn)行提供了所需環(huán)境。具體來(lái)說(shuō)JDK其實(shí)包含了JRE,同時(shí)還包含了編譯java源碼的編譯器javac,還包含了很多java程序調(diào)試和分析的工具。簡(jiǎn)單來(lái)說(shuō):如果你需要運(yùn)行java程序,只需安裝JRE就可以了,如果你需要編寫java程序,需要安裝JDK。
2.==和equals的區(qū)別是什么?
==解讀
對(duì)于基本類型和引用類型==的作用效果是不同的,如下所示:
基本類型:比較的是值是否相同;引用類型:比較的是引用是否相同;代碼示例:
Stringx="string";
Stringy="string";
Stringz=newString("string");
System.out.println(x==y);//true
System.out.println(x==z);//false
System.out.println(x.equals(y));//true
System.out.println(x.equals(z));//true
代碼解讀:因?yàn)閤和y指向的是同一個(gè)引用,所以==也是true,而newString()方法則重寫開辟了內(nèi)存空間,所以==結(jié)果為false,而equals比較的一直是值,所以結(jié)果都為true。
equals解讀
equals本質(zhì)上就是==,只不過(guò)String和Integer等重寫了equals方法,把它變成了值比較??聪旅娴拇a就明白了。
首先來(lái)看默認(rèn)情況下equals比較一個(gè)有相同值的對(duì)象,代碼如下:
classCat{
publicCat(Stringname){
this.name=name;
}
privateStringname;
publicStringgetName(){
returnname;
}
publicvoidsetName(Stringname){
this.name=name;
}
}
Catc1=newCat("提莫");
Catc2=newCat("提莫");
輸出結(jié)果出乎我們的意料,竟然是false?這是怎么回事,看了equals源碼就知道了,源碼如下:
publicbooleanequals(Objectobj){
return(this==obj);
}
復(fù)制代碼
原來(lái)equals本質(zhì)上就是==。
那問(wèn)題來(lái)了,兩個(gè)相同值的String對(duì)象,為什么返回的是true?代碼如下:
Strings1=newString("阿莫");
Strings2=newString("阿莫");
System.out.println(s1.equals(s2));//true
同樣的,當(dāng)我們進(jìn)入String的equals方法,找到了答案,代碼如下:
publicbooleanequals(ObjectanObject){
if(this==anObject){
returntrue;
}
if(anObjectinstanceofString){
StringanotherString=(String)anObject;
intn=value.length;
if(n==anotherString.value.length){
charv1[]=value;
charv2[]=anotherString.value;
inti=0;
while(n--!=0){
if(v1[i]!=v2[i])
returnfalse;
i++;
}
returntrue;
}
}
returnfalse;
}
原來(lái)是String重寫了Object的equals方法,把引用比較改成了值比較。
總結(jié):==對(duì)于基本類型來(lái)說(shuō)是值比較,對(duì)于引用類型來(lái)說(shuō)是比較的是引用;而equals默認(rèn)情況下是引用比較,只是很多類重新了equals方法,比如String、Integer等把它變成了值比較,所以一般情況下equals比較的是值是否相等。
3.兩個(gè)對(duì)象的hashCode()相同,則equals()也一定為true,對(duì)嗎?
不對(duì),兩個(gè)對(duì)象的hashCode()相同,equals()不一定true。
代碼示例:
Stringstr1="通話";
Stringstr2="重地";
System.out.println(String.format("str1:%d|str2:%d",str1.hashCode(),str2.hashCode()));
System.out.println(str1.equals(str2));
執(zhí)行的結(jié)果:
str1:1179395|str2:1179395
false
代碼解讀:很顯然“通話”和“重地”的hashCode()相同,然而equals()則為false,因?yàn)樵谏⒘斜碇?,hashCode()相等即兩個(gè)鍵值對(duì)的哈希值相等,然而哈希值相等,并不一定能得出鍵值對(duì)相等。
4.final在java中有什么作用?
final修飾的類叫最終類,該類不能被繼承。final修飾的方法不能被重寫。final修飾的變量叫常量,常量必須初始化,初始化之后值就不能被修改。
5.java中的Math.round(-1.5)等于多少?
等于-1,因?yàn)樵跀?shù)軸上取值時(shí),中間值(0.5)向右取整,所以正0.5是往上取整,負(fù)0.5是直接舍棄。
6.String屬于基礎(chǔ)的數(shù)據(jù)類型嗎?
String不屬于基礎(chǔ)類型,基礎(chǔ)類型有8種:byte、boolean、char、short、int、float、long、double,而String屬于對(duì)象。
7.java中操作字符串都有哪些類?它們之間有什么區(qū)別?
操作字符串的類有:String、StringBuffer、StringBuilder。
String和StringBuffer、StringBuilder的區(qū)別在于String聲明的是不可變的對(duì)象,每次操作都會(huì)生成新的String對(duì)象,然后將指針指向新的String對(duì)象,而StringBuffer、StringBuilder可以在原有對(duì)象的基礎(chǔ)上進(jìn)行操作,所以在經(jīng)常改變字符串內(nèi)容的情況下最好不要使用String。
StringBuffer和StringBuilder最大的區(qū)別在于,StringBuffer是線程安全的,而StringBuilder是非線程安全的,但StringBuilder的性能卻高于StringBuffer,所以在單線程環(huán)境下推薦使用StringBuilder,多線程環(huán)境下推薦使用StringBuffer。
8.Stringstr="i"與Stringstr=newString("i")一樣嗎?
不一樣,因?yàn)閮?nèi)存的分配方式不一樣。Stringstr="i"的方式,java虛擬機(jī)會(huì)將其分配到常量池中;而Stringstr=newString("i")則會(huì)被分到堆內(nèi)存中。
以上就是長(zhǎng)沙中公優(yōu)就業(yè)Java培訓(xùn)機(jī)構(gòu)小編介紹的“2020年最新整理Java筆試面試題下載”的內(nèi)容,希望對(duì)大家有幫助,如有疑問(wèn),請(qǐng)?jiān)诰€咨詢,有專業(yè)老師隨時(shí)為你服務(wù)。