Java筆試題分析

作者:xcbeyond
瘋狂源自夢(mèng)想,技術(shù)成就輝煌!微信公眾號(hào):《程序猿技術(shù)大咖》號(hào)主,專(zhuān)注后端開(kāi)發(fā)多年,擁有豐富的研發(fā)經(jīng)驗(yàn),樂(lè)于技術(shù)輸出、分享,現(xiàn)階段從事微服務(wù)架構(gòu)項(xiàng)目的研發(fā)工作,涉及架構(gòu)設(shè)計(jì)、技術(shù)選型、業(yè)務(wù)研發(fā)等工作。對(duì)于Java、微服務(wù)、數(shù)據(jù)庫(kù)、Docker有深入了解,并有大量的調(diào)優(yōu)經(jīng)驗(yàn)。

引言:

      到目前為止,接觸java總的時(shí)間大致也就是一年吧。在Java的學(xué)習(xí)過(guò)程中,我也無(wú)不例外的是跟著老師的步伐學(xué)習(xí)著,但學(xué)習(xí)了一段時(shí)間過(guò)后,就找了些筆試面試題目拿來(lái)看了看,發(fā)現(xiàn)面試題中的遇到的題目知識(shí)點(diǎn)都是那么的細(xì)微,平時(shí)沒(méi)過(guò)多的注意,于此我開(kāi)始有了自己新的學(xué)習(xí)方案:大體跟著老師的步伐走,自己下面再深入的學(xué)習(xí)探討每一個(gè)知識(shí)點(diǎn),做到“理解高于一切”的原則。其中一個(gè)重要的途徑就是通過(guò)“面試題目”從中深入學(xué)習(xí)(對(duì)于每一個(gè)面試題目展開(kāi)詳細(xì)的學(xué)習(xí)),畢竟一些面試題目都是很經(jīng)典的嘛!從中也讓我學(xué)到了許多,收獲也不錯(cuò)。于是就整理下來(lái)了……       (實(shí)時(shí)更新中)

       以下題目均收集于網(wǎng)絡(luò),針對(duì)一些題目做出了個(gè)人簡(jiǎn)單的分析評(píng)注(有些參考來(lái)源于網(wǎng)絡(luò)),只當(dāng)對(duì)在java學(xué)習(xí)過(guò)程中不足之處做以補(bǔ)充,使得對(duì)于一些問(wèn)題的理解更加的深入透徹。

1、一個(gè)".java"源文件中是否可以包括多個(gè)類(lèi)(不是內(nèi)部類(lèi))?有什么限制?

可以有多個(gè)類(lèi),但只能有一個(gè)public的類(lèi),并且public的類(lèi)名必須與文件名相一致。

2、Java有沒(méi)有g(shù)oto?

java中的保留字,現(xiàn)在沒(méi)有在java中使用。

 

3、說(shuō)說(shuō)&和&&的區(qū)別。

&和&&都可以用作邏輯與的運(yùn)算符,表示邏輯與(and),當(dāng)運(yùn)算符兩邊的表達(dá)式的結(jié)果都為true時(shí),整個(gè)運(yùn)算結(jié)果才為true,否則,只要有一方為false,則結(jié)果為false。

&&還具有短路的功能,即如果第一個(gè)表達(dá)式為false,則不再計(jì)算第二個(gè)表達(dá)式,例如,對(duì)于if(str != null && !str.equals(“”))表達(dá)式,當(dāng)str為null時(shí),后面的表達(dá)式不會(huì)執(zhí)行,所以不會(huì)出現(xiàn)NullPointerException如果將&&改為&,則會(huì)拋出NullPointerException異常。If(x==33 & ++y>0) y會(huì)增長(zhǎng),If(x==33 && ++y>0)不會(huì)增長(zhǎng)

&還可以用作位運(yùn)算符,當(dāng)&操作符兩邊的表達(dá)式不是boolean類(lèi)型時(shí),&表示按位與操作,我們通常使用0x0f來(lái)與一個(gè)整數(shù)進(jìn)行&運(yùn)算,來(lái)獲取該整數(shù)的最低4個(gè)bit位,例如,0x31 & 0x0f的結(jié)果為0x01。

 

備注:這道題先說(shuō)兩者的共同點(diǎn),再說(shuō)出&&和&的特殊之處,并列舉一些經(jīng)典的例子來(lái)表明自己理解透徹深入、實(shí)際經(jīng)驗(yàn)豐富。

 

4、在JAVA中如何跳出當(dāng)前的多重嵌套循環(huán)?

在Java中,要想跳出多重循環(huán),可以在外面的循環(huán)語(yǔ)句前定義一個(gè)標(biāo)號(hào),然后在里層循環(huán)體的代碼中使用帶有標(biāo)號(hào)的break 語(yǔ)句,即可跳出外層循環(huán)。例如

//方法一:break直接跳轉(zhuǎn)到標(biāo)記處,(不建議的使用)
  ok:
  for(int i = 0;i<arr.length;i++) {
   for(int j =0;j<arr[i].length;j++) {
    System.out.println("j="+j);
    if(arr[i][j]==3) {
     System.out.println("這個(gè)數(shù)"+arr[i][j]+"找到了 ");
     break ok;
    }
   }
  }

 

另外,我個(gè)人通常并不使用標(biāo)號(hào)這種方式,而是讓外層的循環(huán)條件表達(dá)式的結(jié)果可以受到里層循環(huán)體代碼的控制,例如,要在二維數(shù)組中查找到某個(gè)數(shù)字。

//方法二:
  boolean found = false;
  for(int i = 0;i<arr.length&&!found;i++) {
   for(int j = 0;j<arr[i].length;j++) {
    System.out.println("j="+j);
    if(arr[i][j]==3){
     System.out.println("這個(gè)數(shù)"+arr[i][j]+"找到了 ");
     found = true;
     break;
    }
   }
  }
5、switch語(yǔ)句能否作用在byte上,能否作用在long上,能否作用在String上?

在switch(expr1)中,expr1只能是一個(gè)整數(shù)表達(dá)式或者枚舉常量(更大字體),整數(shù)表達(dá)式可以是int基本類(lèi)型或Integer包裝類(lèi)型,由于,byte,short,char都可以隱含轉(zhuǎn)換為int,所以,這些類(lèi)型以及這些類(lèi)型的包裝類(lèi)型也是可以的。顯然,long和String類(lèi)型都不符合switch的語(yǔ)法規(guī)定,并且不能被隱式轉(zhuǎn)換成int類(lèi)型,所以,它們不能作用于swtich語(yǔ)句中。

6、short s1 = 1; s1 = s1 + 1;有什么錯(cuò)? short s1 = 1; s1 += 1;有什么錯(cuò)?

對(duì)于short s1 = 1; s1 = s1 + 1;由于s1+1運(yùn)算時(shí)會(huì)自動(dòng)提升表達(dá)式的類(lèi)型,所以結(jié)果是int型,再賦值給short類(lèi)型s1時(shí),編譯器將報(bào)告需要強(qiáng)制轉(zhuǎn)換類(lèi)型的錯(cuò)誤。

對(duì)于short s1 = 1; s1 += 1;由于 += 是java語(yǔ)言規(guī)定的運(yùn)算符,java編譯器會(huì)對(duì)它進(jìn)行特殊處理,因此可以正確編譯。

package 知識(shí)點(diǎn);
/**
 * i = i+1和i +=1是完全不同的哦!
 * 一個(gè)使用簡(jiǎn)單賦值運(yùn)算,一個(gè)使用復(fù)合賦值運(yùn)算 ,
 *     其差別在于:復(fù)合賦值運(yùn)算會(huì)自動(dòng)地將運(yùn)算結(jié)果轉(zhuǎn)換為左操作數(shù)的類(lèi)型
 * @author xcbeyond
 * @date 2012-4-10 上午11:19:35
 */
public class Short {
    public static void main(String[] args) {
        short i = 1;
        //i = i+1;  //i+1運(yùn)算后的類(lèi)型為int,int->short無(wú)法自動(dòng)類(lèi)型轉(zhuǎn)換
        
        short j = 1;
        j+=1;//i = i+1;和i+=1;是不同的!一個(gè)使用簡(jiǎn)單賦值運(yùn)算,一個(gè)使用復(fù)合賦值運(yùn)算 ,
        //其差別在于:復(fù)合賦值運(yùn)算會(huì)自動(dòng)地將運(yùn)算結(jié)果轉(zhuǎn)換為左操作數(shù)的類(lèi)型
 
    }
 
}
7、char型變量中能不能存貯一個(gè)中文漢字?為什么?

char型變量是用來(lái)存儲(chǔ)Unicode編碼的字符的,unicode編碼字符集中包含了漢字,所以,char型變量中當(dāng)然可以存儲(chǔ)漢字啦。不過(guò),如果某個(gè)特殊的漢字沒(méi)有被包含在unicode編碼字符集中,那么,這個(gè)char型變量中就不能存儲(chǔ)這個(gè)特殊漢字。補(bǔ)充說(shuō)明:unicode編碼占用兩個(gè)字節(jié),所以,char類(lèi)型的變量也是占用兩個(gè)字節(jié)。

備注:后面一部分回答雖然不是在正面回答題目,但是,為了展現(xiàn)自己的學(xué)識(shí)和表現(xiàn)自己對(duì)問(wèn)題理解的透徹深入,可以回答一些相關(guān)的知識(shí),做到知無(wú)不言,言無(wú)不盡。

8、用最有效率的方法算出2乘以8等於幾?

2 << 3,

因?yàn)閷⒁粋€(gè)數(shù)左移n位,就相當(dāng)于乘以了2的n次方,那么,一個(gè)數(shù)乘以8只要將其左移3位即可,而位運(yùn)算cpu直接支持的,效率最高,所以,2乘以8等於幾的最效率的方法是2 << 3。

9、請(qǐng)?jiān)O(shè)計(jì)一個(gè)一百億的計(jì)算器

首先要明白這道題目的考查點(diǎn)是什么,一是大家首先要對(duì)計(jì)算機(jī)原理的底層細(xì)節(jié)要清楚、要知道加減法的位運(yùn)算原理和知道計(jì)算機(jī)中的算術(shù)運(yùn)算會(huì)發(fā)生越界的情況,二是要具備一定的面向?qū)ο蟮脑O(shè)計(jì)思想。

首先,計(jì)算機(jī)中用固定數(shù)量的幾個(gè)字節(jié)來(lái)存儲(chǔ)的數(shù)值,所以計(jì)算機(jī)中能夠表示的數(shù)值是有一定的范圍的,為了便于講解和理解,我們先以byte類(lèi)型的整數(shù)為例,它用1個(gè)字節(jié)進(jìn)行存儲(chǔ),表示的最大數(shù)值范圍為-128到+127。-1在內(nèi)存中對(duì)應(yīng)的二進(jìn)制數(shù)據(jù)為11111111,如果兩個(gè)-1相加,不考慮Java運(yùn)算時(shí)的類(lèi)型提升,運(yùn)算后會(huì)產(chǎn)生進(jìn)位,二進(jìn)制結(jié)果為1,11111110,由于進(jìn)位后超過(guò)了byte類(lèi)型的存儲(chǔ)空間,所以進(jìn)位部分被舍棄,即最終的結(jié)果為11111110,也就是-2,這正好利用溢位的方式實(shí)現(xiàn)了負(fù)數(shù)的運(yùn)算。-128在內(nèi)存中對(duì)應(yīng)的二進(jìn)制數(shù)據(jù)為10000000,如果兩個(gè)-128相加,不考慮Java運(yùn)算時(shí)的類(lèi)型提升,運(yùn)算后會(huì)產(chǎn)生進(jìn)位,二進(jìn)制結(jié)果為1,00000000,由于進(jìn)位后超過(guò)了byte類(lèi)型的存儲(chǔ)空間,所以進(jìn)位部分被舍棄,即最終的結(jié)果為00000000,也就是0,這樣的結(jié)果顯然不是我們期望的,這說(shuō)明計(jì)算機(jī)中的算術(shù)運(yùn)算是會(huì)發(fā)生越界情況的,兩個(gè)數(shù)值的運(yùn)算結(jié)果不能超過(guò)計(jì)算機(jī)中的該類(lèi)型的數(shù)值范圍。由于Java中涉及表達(dá)式運(yùn)算時(shí)的類(lèi)型自動(dòng)提升,我們無(wú)法用byte類(lèi)型來(lái)做演示這種問(wèn)題和現(xiàn)象的實(shí)驗(yàn),大家可以用下面一個(gè)使用整數(shù)做實(shí)驗(yàn)的例子程序體驗(yàn)一下:


 

  int a = Integer.MAX_VALUE; //MAX_VALUE = 0x7fffffff
  int b = Integer.MAX_VALUE;
  int sum = a + b;
  System.out.println(“a=”+a+”,b=”+b+”,sum=”+sum);
先不考慮long類(lèi)型,由于int的正數(shù)范圍為2的31次方,表示的最大數(shù)值約等于2*1000*1000*1000,也就是20億的大小,所以,要實(shí)現(xiàn)一個(gè)一百億的計(jì)算器,我們得自己設(shè)計(jì)一個(gè)類(lèi)可以用于表示很大的整數(shù),并且提供了與另外一個(gè)整數(shù)進(jìn)行加減乘除的功能,大概功能如下:

(1)這個(gè)類(lèi)內(nèi)部有兩個(gè)成員變量,一個(gè)表示符號(hào),另一個(gè)用字節(jié)數(shù)組表示數(shù)值的二進(jìn)制數(shù)

(2)有一個(gè)構(gòu)造方法,把一個(gè)包含有多位數(shù)值的字符串轉(zhuǎn)換到內(nèi)部的符號(hào)和字節(jié)數(shù)組中

(3)提供加減乘除的功能

package BigNumber;
/**
 * 具體參考java.math.BigInteger類(lèi)的源碼
 * 功能如下:
 *   1、這個(gè)類(lèi)內(nèi)部有兩個(gè)成員變量,一個(gè)表示符號(hào),另一個(gè)用字節(jié)數(shù)組表示數(shù)值的二進(jìn)制數(shù)
 *   2、有一個(gè)構(gòu)造方法,把一個(gè)包含有多位數(shù)值的字符串轉(zhuǎn)換到內(nèi)部的符號(hào)和字節(jié)數(shù)組中
 *   3、提供加減乘除的功能
 * @author xcbeyond
 * @date 2012-4-22 下午11:46:05
 */
public class BigInteger {
     private int sign;
     private byte[] val;
     
     public BigInteger(byte[] val)
     {
            
     }
     public BigInteger add(BigInteger other)
     {
        return other;
             
     }
     public BigInteger subtract(BigInteger other)
     {
        return other;
             
     }
     public BigInteger multiply(BigInteger other)
     {
        return other;
             
     }
     public BigInteger divide(BigInteger other)
     {
        return other;
             
     }
 
}

 






備注:要想寫(xiě)出這個(gè)類(lèi)的完整代碼,是非常復(fù)雜的,如果有興趣的話,可以參看jdk中自帶的java.math.BigInteger類(lèi)的源碼。面試的人也知道誰(shuí)都不可能在短時(shí)間內(nèi)寫(xiě)出這個(gè)類(lèi)的完整代碼的,他要的是你是否有這方面的概念和意識(shí),他最重要的還是考查你的能力,所以,你不要因?yàn)樽约簾o(wú)法寫(xiě)出完整的最終結(jié)果就放棄答這道題,你要做的就是你比別人寫(xiě)得多,證明你比別人強(qiáng),你有這方面的思想意識(shí)就可以了,畢竟別人可能連題目的意思都看不懂,什么都沒(méi)寫(xiě),你要敢于答這道題,即使只答了一部分,那也與那些什么都不懂的人區(qū)別出來(lái),拉開(kāi)了距離,算是矮子中的高個(gè),機(jī)會(huì)當(dāng)然就屬于你了。另外,答案中的框架代碼也很重要,體現(xiàn)了一些面向?qū)ο笤O(shè)計(jì)的功底,特別是其中的方法命名很專(zhuān)業(yè),用的英文單詞很精準(zhǔn),這也是能力、經(jīng)驗(yàn)、專(zhuān)業(yè)性、英語(yǔ)水平等多個(gè)方面的體現(xiàn),會(huì)給人留下很好的印象,在編程能力和其他方面條件差不多的情況下,英語(yǔ)好除了可以使你獲得更多機(jī)會(huì)外,薪水可以高出一千元。

擴(kuò)展:(大數(shù)問(wèn)題)

http://blog.csdn.net/xcbeyond/article/details/7524227
10、使用final關(guān)鍵字修飾一個(gè)變量時(shí),是引用不能變,還是引用的對(duì)象不能變?

         使用final關(guān)鍵字修飾一個(gè)變量時(shí),是指引用變量不能變,引用變量所指向的對(duì)象中的內(nèi)容還是可以改變的。例如,對(duì)于如下語(yǔ)句:

                  final StringBuffer s = new StringBuffer("xcbeyond");執(zhí)行如下語(yǔ)句將報(bào)告編譯期錯(cuò)誤:

                 s = new StringBuffer("xcbeyond1");但是,執(zhí)行如下語(yǔ)句則可以通過(guò)編譯:

                 a.append(" hello!");

 

        有人在定義方法的參數(shù)時(shí),可能想采用如下形式來(lái)阻止方法內(nèi)部修改傳進(jìn)來(lái)的參數(shù)對(duì)象:

                 public void method(final  StringBuffer  param)

                {
                }

         實(shí)際上,這是錯(cuò)誤的,因此,final不能修飾方法中的參數(shù)。倘若能夠修飾,則違背了final修飾變量不能修改這一原則。在該方法內(nèi)部仍然可以增加如下代碼來(lái)修改參數(shù)對(duì)象:   param.append("a");

*final回顧:

      1>、final修飾的變量,其引用變量是不可以改變的,而其引用變量指向?qū)ο蟮膬?nèi)容卻是可以改變哦!正如此筆試題所述。

      2>、final 修飾的類(lèi),不能再被繼承。

               - Java 的String就是final類(lèi),不能被繼承!Math 也是final類(lèi)

               - 在實(shí)際項(xiàng)目開(kāi)發(fā)中,原則上不允許使用final類(lèi)!如:Spring,Hibernate,Struts 2,這些框架經(jīng)常動(dòng)態(tài)代理(動(dòng)態(tài)繼承)技術(shù)。使用final的類(lèi)可以造成這些框架的工作  問(wèn) 題。

      3>、final修飾的方法,不能再被覆蓋。

             在實(shí)際項(xiàng)目開(kāi)發(fā)中,原則上不允許使用final方法!

       4>、final修飾的變量,初始化以后不允許再修改。

       5>、final static , java使用final static 修飾的變量作為一般要求變量名都有大寫(xiě)字母。

11、"=="和equals方法究竟有什么區(qū)別?

        (只有徹徹底底的搞清楚了數(shù)據(jù)、變量是怎么在內(nèi)存中存儲(chǔ)的,具體在哪存放,理解起這就容易了。有時(shí)不妨畫(huà)畫(huà)其存儲(chǔ)時(shí),在內(nèi)存中如何存放,如何指向,這樣你就會(huì)一目了然了。其次就是多舉例驗(yàn)證,分析其不同之處?。?br>
        ==操作符專(zhuān)門(mén)用來(lái)比較兩個(gè)變量的值是否相等,也就是用于比較變量所對(duì)應(yīng)的內(nèi)存中所存儲(chǔ)的數(shù)值是否相同,要比較兩個(gè)基本類(lèi)型的數(shù)據(jù)或兩個(gè)引用變量是否相等,只能用==操作符。如果一個(gè)變量指向的數(shù)據(jù)是對(duì)象類(lèi)型的,那么,這時(shí)候涉及了兩塊內(nèi)存,對(duì)象本身占用一塊內(nèi)存(堆內(nèi)存),變量也占用一塊內(nèi)存(棧),例如Objet obj = new Object();變量obj存放在棧中,對(duì)象new Object()存放在堆內(nèi)存中,此時(shí),變量obj所對(duì)應(yīng)的內(nèi)存中存儲(chǔ)的數(shù)值就是對(duì)象占用的那塊內(nèi)存的首地址。對(duì)于指向?qū)ο箢?lèi)型的變量,如果要比較兩個(gè)變量是否指向同一個(gè)對(duì)象,即要看這兩個(gè)變量所對(duì)應(yīng)的內(nèi)存中的數(shù)值是否相等,這時(shí)候就需要用==操作符進(jìn)行比較。

          equals方法是用于比較兩個(gè)獨(dú)立對(duì)象的內(nèi)容是否相同,就好比去比較兩個(gè)人的長(zhǎng)相是否相同,它比較的兩個(gè)對(duì)象是獨(dú)立的。例如,對(duì)于下面的代碼:

                      String a=new String("foo");

                       String b=new String("foo");

        兩條new語(yǔ)句創(chuàng)建了兩個(gè)對(duì)象,然后用a,b這兩個(gè)變量分別指向了其中一個(gè)對(duì)象,這是兩個(gè)不同的對(duì)象,它們的首地址是不同的,即a和b中存儲(chǔ)的數(shù)值是不相同的,所以,表達(dá)式a==b將返回false,而這兩個(gè)對(duì)象中的內(nèi)容是相同的,所以,表達(dá)式a.equals(b)將返回true。

        如果一個(gè)類(lèi)沒(méi)有自己定義equals方法,那么它將繼承Object類(lèi)的equals方法,Object類(lèi)的equals方法的實(shí)現(xiàn)代碼如下:

                 boolean equals(Object o){
                      return this==o;

                 }

       這說(shuō)明,如果一個(gè)類(lèi)沒(méi)有自己定義equals方法,它默認(rèn)的equals方法(從Object 類(lèi)繼承的)就是使用==操作符,也是在比較兩個(gè)變量指向的對(duì)象是否是同一對(duì)象,這時(shí)候使用equals和使用==會(huì)得到同樣的結(jié)果,如果比較的是兩個(gè)獨(dú)立的對(duì)象則總返回false。如果你編寫(xiě)的類(lèi)希望能夠比較該類(lèi)創(chuàng)建的兩個(gè)實(shí)例對(duì)象的內(nèi)容是否相同,那么你必須覆蓋equals方法,由你自己寫(xiě)代碼來(lái)決定在什么情況即可認(rèn)為兩個(gè)對(duì)象的內(nèi)容是相同的。

12、靜態(tài)變量和實(shí)例變量的區(qū)別?

      在語(yǔ)法定義上的區(qū)別:靜態(tài)變量前要加static關(guān)鍵字,而實(shí)例變量前則不加。(光知道這些是完全不夠的,還需要進(jìn)一步的分析討論)。

       靜態(tài)變量,是屬于類(lèi)的(因此,也稱為類(lèi)變量),不屬于某個(gè)具體的實(shí)例,它被該類(lèi)所有的實(shí)例所共享,即:100個(gè)該類(lèi)的實(shí)例也就只有一個(gè)變量(靜態(tài)變量),它可以直接被類(lèi)來(lái)調(diào)用使用,如Math.sqrt()方法。實(shí)例變量是屬于每個(gè)實(shí)例的,該類(lèi)的每個(gè)實(shí)例都有一個(gè)該變量(實(shí)例變量)。只要程序加載了類(lèi),不用創(chuàng)建任何實(shí)例對(duì)象,靜態(tài)變量就會(huì)被分配空間,靜態(tài)變量就可以被使用了。總之,實(shí)例變量必須創(chuàng)建對(duì)象后才可以通過(guò)這個(gè)對(duì)象來(lái)使用,靜態(tài)變量則可以直接使用類(lèi)名來(lái)引用。

13、是否可以從一個(gè)static方法內(nèi)部發(fā)出對(duì)非static方法的調(diào)用?

          不可以。因?yàn)榉莝tatic方法是要與對(duì)象關(guān)聯(lián)在一起的,必須創(chuàng)建一個(gè)對(duì)象后,才可以在該對(duì)象上進(jìn)行方法調(diào)用,而static方法調(diào)用時(shí)不需要?jiǎng)?chuàng)建對(duì)象,可以直接調(diào)用。也就是說(shuō),當(dāng)一個(gè)static方法被調(diào)用時(shí),可能還沒(méi)有創(chuàng)建任何實(shí)例對(duì)象,如果從一個(gè)static方法中發(fā)出對(duì)非static方法的調(diào)用,那個(gè)非static方法是關(guān)聯(lián)到哪個(gè)對(duì)象上的呢?這個(gè)邏輯無(wú)法成立,所以,一個(gè)static方法內(nèi)部發(fā)出對(duì)非static方法的調(diào)用。

/**
 * static
 * @author xcbeyond
 * @date 2012-5-8 下午07:51:34
 */
public class Static {
    public static void main(String[] args) {
        
    }
    
    public static void method1() {
        //method2(); //錯(cuò)     不可以從一個(gè)static方法內(nèi)部發(fā)出對(duì)非static方法的調(diào)用
        /**
         * 因?yàn)榉莝tatic方法是要與對(duì)象關(guān)聯(lián)在一起的,必須創(chuàng)建一個(gè)對(duì)象后,才可以在該對(duì)象上進(jìn)行方法調(diào)用,
         * 而static方法調(diào)用時(shí)不需要?jiǎng)?chuàng)建對(duì)象,可以直接調(diào)用。
         */
        System.out.println("靜態(tài)方法!");
    }
    public void method2() {
        method1();//實(shí)際上等同于Static.method1();
        System.out.println("非靜態(tài)方法!");
    }
}

 

14、Integer與int的區(qū)別?

        int是java提供的8種原始數(shù)據(jù)類(lèi)型之一。Java為每個(gè)原始類(lèi)型提供了封裝類(lèi),Integer是java為int提供的封裝類(lèi)。int的默認(rèn)值為0,而Integer的默認(rèn)值為null,即Integer可以區(qū)分出未賦值和值為0的區(qū)別,int則無(wú)法表達(dá)出未賦值的情況,例如,要想表達(dá)出沒(méi)有參加考試和考試成績(jī)?yōu)?的區(qū)別,則只能使用Integer。在JSP開(kāi)發(fā)中,Integer的默認(rèn)為null,所以用el表達(dá)式在文本框中顯示時(shí),值為空白字符串,而int默認(rèn)的默認(rèn)值為0,所以用el表達(dá)式在文本框中顯示時(shí),結(jié)果為0,所以,int不適合作為web層的表單數(shù)據(jù)的類(lèi)型。

        在Hibernate中,如果將OID定義為Integer類(lèi)型,那么Hibernate就可以根據(jù)其值是否為null而判斷一個(gè)對(duì)象是否是臨時(shí)的,如果將OID定義為了int類(lèi)型,還需要在hbm映射文件中設(shè)置其unsaved-value屬性為0。

         另外,Integer提供了多個(gè)與整數(shù)相關(guān)的操作方法,例如,將一個(gè)字符串轉(zhuǎn)換成整數(shù),Integer中還定義了表示整數(shù)的最大值和最小值的常量。

15、Math.round(11.5)等于多少? Math.round(-11.5)等于多少?

        Math類(lèi)中提供了三個(gè)與取整有關(guān)的方法:ceil、floor、round,這些方法的作用與它們的英文名稱的含義相對(duì)應(yīng),例如,ceil的英文意義是天花板,該方法就表示向上取整,所以,Math.ceil(11.3)的結(jié)果為12,Math.ceil(-11.3)的結(jié)果是-11;floor的英文意義是地板,該方法就表示向下取整,所以,Math.floor(11.6)的結(jié)果為11,Math.floor(-11.6)的結(jié)果是-12;最難掌握的是round方法,它表示“四舍五入”,算法為Math.floor(x+0.5),即將原來(lái)的數(shù)字加上0.5后再向下取整,所以,Math.round(11.5)的結(jié)果為12,Math.round(-11.5)的結(jié)果為-11。