18禁网站免费,成年人黄色视频网站,熟妇高潮一区二区在线播放,国产精品高潮呻吟AV

學(xué)習(xí)啦 > 創(chuàng)業(yè)指南 > 職場 > 面試題 > java初級工程師面試題

java初級工程師面試題

時間: 護(hù)托1061 分享

java初級工程師面試題

  根據(jù)《Java面試問題集》、《Java程序員面試寶典》、《程序員面試寶典》等書籍概括精選而來的面試題都是干貨!下面就由學(xué)習(xí)啦小編為大家介紹一下java初級工程師面試題的文章,歡迎閱讀。

  java初級工程師面試題篇1

  1.Java中的作用域public,private,protected,以及不寫作用域(default)時有什么區(qū)別?

  Java中有四種作用域,按照作用域范圍由大到小排列一次是:public , protected , default , private。

  private表示只能在當(dāng)前類中使用;

  default表示只能在當(dāng)前類或者是同一個包下面使用;

  protected表示可以在當(dāng)前類,同一個包下,當(dāng)前類的子類中使用;

  public表示除了上面的情況外,還可以被其它包中的類使用。

  2.匿名內(nèi)部類是否可以繼承其它類,是否可以實現(xiàn)其它接口?

  首先需要搞清楚內(nèi)部類和匿名內(nèi)部類的概念和特點,可以參考以下鏈接:

  http://android.blog.51cto.com/268543/384844/

  http://www.cnblogs.com/o-andy-o/archive/2012/04/07/2435825.html

  內(nèi)部類分為三種:成員內(nèi)部類,局部內(nèi)部類(又稱方法內(nèi)部類),匿名內(nèi)部類。(這里不把靜態(tài)嵌套類歸類于內(nèi)部類,在后面會單獨講到)

  本題問的是匿名內(nèi)部類,那么我們來看一段代碼:

  public class Car {

  public void drive() {

  System.out.println("drive a car!");

  }

  }1234512345

  public class Outer {

  public static void main(String[] args) {

  Car car = new Car(){

  //要使用匿名內(nèi)部類必須先定義該類(接口)

  //此處匿名內(nèi)部類會默認(rèn)繼承已經(jīng)定義的類(Car)

  public void drive() {

  System.out.println("drive another car!");

  }

  };

  car.drive();

  }

  }123456789101112123456789101112

  其中,new Car()就是一個匿名內(nèi)部類,繼承了它的父類Car。

  所以,本題答案是匿名內(nèi)部類可以而且是必須繼承一個父類或者實現(xiàn)一個接口。

  3.靜態(tài)嵌套類和內(nèi)部類的區(qū)別。

  首先,我們看一下靜態(tài)嵌套類的例子:

  public class Outer {

  public static void main(String[] args) {

  Outer.Inner inner = new Inner();

  Outer.Inner.print();

  }

  public static class Inner {

  public static void print() {

  }

  }

  }

  123456789101112123456789101112

  該靜態(tài)嵌套內(nèi)部類可以像其它靜態(tài)成員一樣,沒有外部類對象時也能夠通過外部類的類名訪問它。但是,它不能訪問外部類的成員和方法,因為無法知道外部類是否生成對象,只有外部類實例化了對象,外部類才會有成員和方法。

  而內(nèi)部類必須要實例化外部類的對象才能被訪問,而且,內(nèi)部類是可以通過Outer.this來獲取外部類對象,從而訪問外部類的成員和方法。

  4.&和&&的區(qū)別。

  &是位運算符,&&是邏輯運算符。位運算2&3=2是因為轉(zhuǎn)換為二進(jìn)制為10&11=10,10是2的二進(jìn)制表示。邏輯運算true&&false=false。在Java中&也可也用來做邏輯運算true&false=false。

  它們的區(qū)別在于:在做邏輯運算的時候,&&具有短路的功能,而&不具備。下面舉例說明。

  public class TestAnd {

  //類變量,不會被初始化,值為null

  public static String str1;

  public static String str2;

  public static void main(String[] args) {

  if(str1 != null && str2.equals(“”)) {

  ...

  } else {

  ...

  }

  }

  }1234567891011121312345678910111213

  當(dāng)使用&&時,首先判斷str1 != null 為false,所以短路,不會執(zhí)行后面的操作。

  當(dāng)使用&時,雖然前面為false,但是仍然執(zhí)行后面的判斷str2.equals(""),此時會拋出空指針異常。

  java初級工程師面試題篇2

  1.Java中Collection和Collections的區(qū)別。

  Collection是Java集合框架中最上級的接口之一。Collection的實現(xiàn)類主要有List,Queue,Set等等。

  Colelctions是Collection集合框架的一個幫助類(工具類),它直接繼承Object,不屬于集合框架,主要提供一系列的靜態(tài)方法對Collection集合進(jìn)行各種操作。

  2.String s = new String(“abc”);這句話創(chuàng)建了幾個對象?

  兩個。new String(“abc”)是一個字符串對象;s是一個字符串對象的引用對象。

  3.Math.round(11.5),Math.round(-11.5),Math.floor(11.7),Math.floor(-11.7)的值各是多少?

  Math.round(a)是四舍五入;Math.floor(a)是返回小于等于a的最大的double值(即向下取整)。

  所以答案為:12,-11,11,-12

  另外:還有一個ceil方法是向上取整。

  4.short s1 = 1;s1=s1+1和short s1 = 1;s1+=1;有什么區(qū)別?

  s1 + 1會自動向上轉(zhuǎn)型成為int,將int賦給short會編譯報錯,需要強制類型轉(zhuǎn)換:s1 = (short)s1 + 1;

  對于s1 += 1;編譯器會自動將+=后面的操作數(shù)強制轉(zhuǎn)換成前面變量的類型,然后在變量所在的內(nèi)存區(qū)上直接根據(jù)右邊的操作數(shù)修改左邊變量內(nèi)存存儲的二進(jìn)制數(shù)值,屬于位運算,能正確通過編譯。

  另外,后一種方式屬于位運算,效率比前者要高。

  5.Java中有沒有g(shù)oto語句?

  Java關(guān)鍵字:共51個。

  Java保留字:共14個,表示現(xiàn)有的Java版本尚未使用,但以后版本可能會作為關(guān)鍵字使用。

  其中,goto就是Java的保留字。

  6.數(shù)組有沒有l(wèi)ength()這個方法,String有沒有l(wèi)ength()這個方法?

  數(shù)組沒有l(wèi)ength()方法,但是有l(wèi)ength屬性。String有l(wèi)ength()方法。

  補充:集合框架測量長度的方法是size()。

  java初級工程師面試題篇3

  1.簡述Overload(重載)和Override(重寫)的區(qū)別。

  重載和重寫是Java多態(tài)中的內(nèi)容。重寫是父類與子類之間多態(tài)性的一種表現(xiàn),重載是一個類中多態(tài)性的一種表現(xiàn)。

  重載是在一個類中定義多個同名的方法,但是允許這些方法的返回值類型,參數(shù)列表,訪問修飾符,異常等不同。換言之,除了方法名之外,其它都可以不同。

  重寫是因為子類想對父類中某個方法的功能做修改,而不再增加一個新的方法。重寫的要求比較嚴(yán)格,返回值類型,方法名稱,參數(shù)列表必須嚴(yán)格一致,訪問修飾符必須大于等于被重寫的方法,比如,父類的訪問修飾符是protected,子類重寫方法的修飾符可以是protected或者是public。

  值得一提的是,如果父類的方法是private,那么子類中重寫的這個方法就不能算是重寫,相當(dāng)于子類中增加了一個全新的方法。重寫的方法不能拋出新的異常類型,但是允許是原異常類型的子類異常。

  2.集合框架Set中的元素能否重復(fù)?用什么方法來判斷集合中的元素是否重復(fù)?用==還是equals()?它們有什么區(qū)別?

  Set是不能存放重復(fù)元素的,即使是null,在Set中也只能存放一個。Set中元素的順序和元素的插入順序無關(guān),是由Set內(nèi)部的排序機(jī)制自行排序的。

  再來說說==和equals()的區(qū)別:

  當(dāng)比較雙方是基本數(shù)據(jù)類型的時候,應(yīng)該使用==來進(jìn)行比較,比較的是它們的值。

  當(dāng)比較雙方是復(fù)合數(shù)據(jù)類型的時候,可以使用==也可以使用equals()來進(jìn)行比較。

  首先,當(dāng)使用==時,比較的是它們在內(nèi)存中的存放地址。當(dāng)使用equals()方法時,默認(rèn)比較的是兩者的內(nèi)存地址,和==一樣。這是因為在Object這個類中定義了這個比較內(nèi)存地址的equals()方法。但在一些類庫中這個equals()方法被重寫了,比如String,Integer和Date等,在這類中equals()就有了它們自己的實現(xiàn),比較的就不一定是兩者的內(nèi)存地址了。如果想讓兩個復(fù)合數(shù)據(jù)類型的equals方法比較的是它們的值而不是地址,需要重寫hashCode和equals方法。

  3.給我一個你最常見到的runtime exception

  ArithmeticException,

  BufferOverFlowException,

  ClassCastException,

  IllegalArgumentException,

  NullPointerException…

  Exception:http://blog.csdn.net/hguisu/article/details/6155636

  4.Error和Exception的區(qū)別。

  Error和Exception都是Throwable的子類。

  Error是程序無法處理的錯誤,表示運行應(yīng)用程序中較嚴(yán)重的問題,比如內(nèi)存溢出。

  Exception是程序本身可以處理的異常,表示一種設(shè)計或者實現(xiàn)上的問題。

  詳見http://blog.csdn.net/hguisu/article/details/6155636

  5.List,Set,Map是否繼承自Collection接口?

  List和Set是,Map不是。

  可以參考Java集合框架的繼承圖。

  http://blog.csdn.net/zsw101259/article/details/7570033

  6.abstract class(抽象類)和interface(接口)有什么區(qū)別?

  說到抽象類和接口,不得不先說一下抽象方法,有關(guān)抽象方法,抽象類和接口的知識詳細(xì)參見:

  http://www.cnblogs.com/dolphin0520/p/3811437.html

  這里補充強調(diào)一下區(qū)別:

  a)抽象類可以有構(gòu)造方法,接口中不能有構(gòu)造方法。(雖然抽象類不能創(chuàng)建實例對象)

  b)抽象類的成員變量可以是各種類型的,接口中的成員變量是public static final 類型的。

  c)抽象類可以有抽象方法,也可以有具體實現(xiàn)的方法;接口只能有抽象方法。

  d)抽象類的抽象方法可以是public和protected,接口的抽象方法只能是public abstract。

  e)抽象類中可以有靜態(tài)方法和靜態(tài)代碼塊,接口中不行。

  f)單繼承,多實現(xiàn)。

  g)從使用方面來說,繼承是為了代碼的復(fù)用,接口是為了系統(tǒng)的邏輯設(shè)計。

  7.抽象方法是否可以用static,native,synchronized來修飾嗎?

  在類中,沒有方法體的方法就是抽象方法。

  構(gòu)造方法,靜態(tài)方法,私有方法,final方法不能被聲明為抽象方法,抽象方法也不能使用native,static,final,private,protected,synchronized來修飾。

  原因:

  抽象方法是需要在子類中實現(xiàn)的,本身沒有實現(xiàn)體,通過抽象類名來調(diào)用這個沒有實現(xiàn)體的抽象靜態(tài)方法完全沒有意義,所以抽象方法不能是static。

  雖然native修飾的方法不能有實現(xiàn)體但卻表示該方法要用另外一種編程語言實現(xiàn),不存在被子類實現(xiàn)的問題,所以native方法不能是abstract的。因此,抽象方法不能是native。

  一個抽象方法沒有實現(xiàn)體,需要synchronized有什么用,也不行。

  8.接口是否可以繼承接口,抽象類是否可以實現(xiàn)接口,抽象類是否可以繼承實體類?抽象類中是否可以有靜態(tài)的main方法?

  接口可以繼承接口,抽象類可以實現(xiàn)接口,但接口不能繼承抽象類,抽象類也可以繼承實體類,但前提是實體類必須有明確的構(gòu)造函數(shù)(或者說,實體類中必須有子類可以訪問的構(gòu)造函數(shù))。抽象類中可以有靜態(tài)的main方法這個詳見:

  http://blog.sina.com.cn/s/blog_7042a6c101013ung.html

  tips:抽象類和具體類的區(qū)別:抽象類用abstract修飾,抽象類不能被實例化,抽象類中允許有抽象方法。

  9.構(gòu)造器(構(gòu)造函數(shù))能否被重寫?

  一個類的構(gòu)造函數(shù)不能被重寫,但是可以重載。

  10.是否可以繼承String類?

  查閱JDK幫助文檔,可以看到String類的定義聲明:

  public final class String extends Object implements Serializable, Comparable, CharSequence由于是final類型的,所以,String類是不能被繼承的。

  建議:String類的所有方法都要看一下,考的很多。

3151034