精品伊人久久大香线蕉,开心久久婷婷综合中文字幕,杏田冲梨,人妻无码aⅴ不卡中文字幕

打開APP
userphoto
未登錄

開通VIP,暢享免費電子書等14項超值服

開通VIP
Java開發工程師最新面試題庫系列——Java基礎部分(附答案)

JAVA基礎

如果你有更好的想法請在評論區留下您的答案,一起交流討論

  1. 面向對象有哪些特征?

    答:繼承、封裝、多態

  2. JDK與JRE的區別是什么?

    答:JDK是java開發時所需環境,它包含了Java開發時需要用到的API,JRE是Java的運行時環境,JDK包含了JRE,他們是包含關系

  3. Java有哪幾種基本數據類型?

    答:8種,分別是int、byte、short、long、double、flot、char、boolean

  4. == 和equals比較有什么區別?

    答:是Java中的操作符,equals是Java中Object對象提供的對象比較Api。它們的區別是比較的是左右兩邊對象的內存地址,而equals比較的是左右對象的值

  5. public,private,protected,默認的區別什么?

    答:它們是java中的權限修飾符,public可以在任何地方訪問,private僅僅只能在本類中訪問,protected可以在本類以及本類的子類中訪問,默認則代表可以在本包中訪問

  6. short s1=1; s1+=1;有錯嗎? s1=s1+1; 有錯嗎?

    答:short在和int類型進行計算的時候會轉換為int類型,原因是Java中精度小于int的數值運算的時候都回被自動轉換為int后進行計算。計算后的結果也是int,再將int類型賦值給short類型當然會報錯,所以s1=s1+1是錯誤的,然而s1+=1是java底層采用了編譯語法糖的形式完成的轉換,在編譯后依然是轉換為int計算只不過最終做了一次強轉

  7. float f = 1.9; 有錯嗎?

    答:有錯,因為在Java中字面量的小數指的是double類型,double為8個字節float為4個字節,無法完成自動轉換。如果需要將字面量的小數轉換為float類型需要在小數后面加f或者F

  8. &和&&有什么區別?

    答:前者是與符號,后者是短路與符號。前者除了可以做邏輯運算和可以做位運算稱為“按位與”,后者只能做邏輯運算,其次再邏輯運算中,這兩個符號都需要左右兩側表達式為true時,最后結果才為true

  9. 2*8最有效率的計算方法是什么?

    答:2 << 3

  10. 怎么理解值傳遞和引用傳遞?

    答:值傳遞傳遞的是變量中的數據,應用傳遞則是傳遞變量的引用而不是值

  11. Java到底是值傳遞還是引用傳遞?

    答:Java中8種基本數據類型傳遞的是值,而引用數據類型傳遞的是引用

  12. 一個".java"源文件的類有什么限制?

    答:最多只能有一個public static void mian方法,最少有一個類

  13. final關鍵字有哪些用法?

    答:修飾類:最終類,不可被子類繼承,修飾方法:最終方法,不可被子類進行方法覆蓋,修飾變量:常量,必須在聲明時賦值,且之后的程序中不可改變。

  14. final、finally、finalize有什么區別?

    答:除了名稱相像,都比相同。final屬于java的修飾符,finally是結合Java異常體現中的Try一起使用的標識符用來關閉一些資源,finalize是Object根類中的一個方法,是對象被回收之前執行的方法。

  15. void和Void有什么區別?

    答:void是關鍵字在java中代表返回值為空,Void是類名

  16. 為什么byte的取值范圍為-128~127?

    答:2的8次方,且減去正數的零

  17. char類型可以存儲中文漢字嗎?

    答:可以,char默認為2個字節,不過char采用的是UTF-16BE的編碼集,且該編碼集支持中文,char可以動態的更具字符內容改變字節,最大可以到4

  18. 重載和重寫有什么區別?

    答:重載是在同一類中,滿足重載需要方法名相同,參數列表不同,與返回值和訪問修飾符無關。重寫是在繼承關系中,子類對父類方法的覆蓋,需要滿足“一同兩小一大”(方法名相同,返回值類型小于等于父類方法,聲明拋出異常小于等于父類方法,訪問權限修飾符大于等于父類方法)

  19. 構造器可以被重寫和重載嗎?

    答:構造器可以被重載,但是不能被重寫,因為構造器不能被繼承

  20. Java中的斷言(assert)是什么?

    答:用于檢測表達式或方法的最終結果是否符合預期

  21. Error和Exception有哪些區別?

    答:Error是系統錯誤,一般由于系統原因或JVM內部錯誤引起,無法被程序捕獲處理,Exception是程序異常,其中又分編譯時(檢查時)異常和運行時異常,可以被程序捕獲處理,一般我們在開發中針對運行時異常進行處理。

  22. Java中常見的異常有哪些?

    答:NullPointException空指針異常、Arithmeticexception算數異常、ClassCastException類型轉換異常、ClassNotFoundException類為找到異常、illegalargumentexception方法參數錯誤異常、ArrayIndexOfOutBoundsException數組索引越界異常

  23. Java中常見的運行時異常有哪些?

    答:NoSuchMethodError 為找到方法異常(反射調用方法時),NumberFormatException 數值轉換異常,NullPointException空指針異常、Arithmeticexception算數異常、ClassCastException類型轉換異常

  24. 運行時異常和受檢異常有什么區別?

    答:

    運行時異常包括 RuntimeException 類及其子類,表示 JVM 在運行期間可能出現的異常。Java 編譯器不會檢查運行時異常。

    受檢異常是Exception 中除 RuntimeException 及其子類之外的異常。Java 編譯器會檢查受檢異常。

    RuntimeException異常和受檢異常之間的區別:是否強制要求調用者必須處理此異常,如果強制要求調用者必須進行處理,那么就使用受檢異常,否則就選擇非受檢異常(RuntimeException)。一般來講,如果沒有特殊的要求,我們建議使用RuntimeException異常。

  25. 什么時候會發生空指針異常?

    答:對值為空的變量進行操作時

  26. 你知道有哪些避免空指針異常的方法?

    答:對值為空的變量進行操作時先判斷是否為空

  27. throw和throws有什么區別?

    答:throw用于在方法中拋出異常,throws寫在方法名稱后面,用于聲明拋出的異常類型

  28. try里面return,finally還會執行嗎?

    答:會的,除了System.exit(0)finally都會執行

  29. int和Integer有什么區別?

    答:int是java的基本數據類型,Integer是Java的引用數據類型。Integer是int的包裝類,它提供了對int的轉換和計算等API,操作起來更加方便

  30. 什么是包裝類型?有什么用?

    答:包裝類型是對基本數據類型的封裝,底層其實就是對基本數據類型的操作提供了API和語法糖

  31. 什么是自動裝箱和拆箱?

    答:基本數據類型轉引用數據類型為自動拆箱,反之為自動裝箱

  32. 你怎么理解Java中的自動類型轉換和強制類型轉換?

    答:小轉大自動轉換,拓展變量的內存字節。大轉小強制轉換,縮小內存字節損失精度

  33. 你怎么理解Java中的類型提升?

    答:語法糖

  34. 你怎么理解強、軟、弱、虛引用?

    答:

  35. switch是否能用在long上?

    答:可以,switch支持int、byte、short、char以及對應的包裝類,和String類型

  36. switch case支持哪幾種數據類型?

    答:如上

  37. String的底層實現是怎樣的?

    答:char數組,以及字符串常量池

  38. String是可變的嗎?為什么?

    答:不可變,java中的字面量字符串都存放在字符串常量池中,無法改變,只能引用

  39. 為什么不能用 + 拼接字符串?

    答:因為如果用+號拼接字符串JVM編譯時會進行優化,轉變為StringBuilder拼接。單個表達式使用問題不大,但是如果是多個表達式或者在循環內使用會頻繁創建StringBuilder對象大大降低性能

  40. StringBuffer和StringBuilder有什么區別?

    答:前者線程安全效率低,后者線程不安全效率高,

  41. StringJoiner有什么用?

    答:用于做字符串拼接的工具類

    //間隔符是,
    StringJoiner joiner1 = new StringJoiner(",");
    joiner1.add("1").add("2").add("3");
    System.out.println(joiner1.toString());
    //1,2,3
    
    //以[開頭中間的間隔符是,以]結尾
    StringJoiner joiner2 = new StringJoiner(",", "[", "]");
    joiner2.add("1").add("2").add("3");
    System.out.println(joiner2.toString());
    //[1,2,3]
    
    //拼接sql 的in條件的時候, 使用這個就方便很多了
    StringJoiner joiner3 = new StringJoiner("','", "'", "'");
    joiner3.add("1").add("2");
    //'1','2'
    
    
  42. 普通類和抽象類有什么區別?

    答:抽象類被abstract所修飾,

  43. 靜態內部類和普通內部類有什么區別?

    答:普通內部類持有外部外部類的應用,可以調用外部類的屬性及方法,而靜態內部類沒有持有外部內引用,無法調用外部內的方法及屬性。靜態內部類可以有靜態成員(方法,屬性),而非靜態內部類則不能有靜態成 員(方法,屬性)。 非靜態內部類能夠訪問外部類的靜態和非靜態成員。靜態內部類不能訪問外 部類的非靜態成員,只能訪問外部類的靜態成員。

    實例化方式不同:

    1. 靜態內部類:不依賴于外部類的實例,直接實例化內部類對象
    2. 非靜態內部類:通過外部類的對象實例生成內部類對象
  44. 靜態方法可以直接調用非靜態方法嗎?為什么?

    答:不能,因為靜態方法的加載順序優先于非靜態方法,且靜態方法屬于類,無需對象實例,非靜態方法則需要類的實例才能調用

  45. 靜態變量和實力變量有什么區別?

    答:靜態變量屬于類,無需創建對象通過類名即可調用,而實例變量需要類創建實例才可以調用。加載角度而言只要JVM加載了靜態變量所處的類,靜態變量就以及可以使用,為分配了空間。而實例變量需要創建對象之后才會為其分配空間

  46. 內部類可以訪問其外部類的成員嗎?

    答:非靜態內部類可以,因為它持有者外部內的引用。

  47. 接口和抽象類有什么區別?

    答:接口沒有構造方法,抽象類有。抽象類中可以有普通成員變量;接口中沒有普通成員變量。抽象類中可以包含非抽象普通方法;接口中的所有方法必須都是抽象的,不能有非抽象的方法。一個類可以實現多個接口,用逗號隔開,但只能繼承一個抽象類;接口不可以實現接口,但可以繼承接口,并且可以繼承多個接口,用逗號隔開。

  48. 接口里面可以寫方法實現嗎?

    答:可以,jdk1.8之后可以寫接口的默認方法實現

  49. Java中的UUID是什么?

    答:生成一串隨機的數字,它保證對在同一時空中的所有機器都是唯一的

  50. Java類初始化順序是怎樣的?

    答:如下

  51. hashCode有什么作用?

    答:hashcode在java中用于表示對象的唯一碼。hashcode也用在Hash數據結構中,用來計算對象存放在Hash中的位置(存儲地址)

  52. hashCode和identityHashCode的區別?

    答:

    1. Object類中的hashCode方法會返回一個hash碼,只有指向同一個對象的引用變量調用才會返回相同值,而String類中放寬了要求,對象里的值相等也返回相同值
    2. identityHashCode方法是System類中的方法,調用該方法時,不管類中是否重寫了Object類中的hashCode方法,都執行Object類中的hashCode方法,返回一個hashCode值。所以只有指向同一個對象的引用變量調用才會返回相同值
  53. 什么是Hash沖突?

    答:兩個對象都放入同一個hash容器中,且計算出的hash值都相同。也稱為hash碰撞,此時的解決辦法是再hash

  54. Java常用的元注解有哪些?

    答:

    @Target:描述了注解修飾的對象范圍

    • METHOD:用于描述方法
    • PACKAGE:用于描述包
    • PARAMETER:用于描述方法變量
    • TYPE:用于描述類、接口或enum類型

    @Inherited:使被它修飾的注解具有繼承性

    @Retention:表示注解的運行時期范圍

    • RetentionPolicy.SOURCE -------------注解將被編譯器丟棄
    • RetentionPolicy.CLASS -------------注解在class文件中可用,但會被VM丟棄
    • RetentionPolicy.RUNTIME ---------VM將在運行期也保留注釋,因此可以通過反射機制讀取注解的信息

    @Documented:使用 javadoc 工具為類生成幫助文檔時是否要保留其注解信息

  55. Java泛型中的T、R、K、V、E分別指什么?

    答:

    • ? --不確定的Java類型,是一個通配符泛型
    • T --表示確定的Java類型
    • K、V --Java中的鍵值對key、value
    • E --Element (在集合中使用,因為集合中存放的是元素,也表示Collection容器中的類型)
      Java源碼中的Class代表這個類型所對應的類,而Class<?>表示類型不確定的類。
  56. Java金額計算怎么避免精度丟失?

    答:使用BigDecimal進行與金錢相關的計算

  57. Java語法糖是什么意思?

    答:通過提供簡單的編寫方式在編譯時完成對復雜操作的轉換。通常是指Java中的簡單語法,在編譯時期還原成基礎語法。

  58. transient關鍵字有什么作用?

    答:將不需要序列化的屬性前添加關鍵字transient,序列化對象的時候,這個屬性就不會被序列化

  59. 如何實現對象克隆?

    答:Java對象克隆又分深拷貝和淺拷貝,淺拷貝調用Object跟對象繼承下來的clone,深拷貝可以借助SpringFramework提供的BeanUtils工具或者通過Java的序列化與反序列化實現。

  60. 對象克隆淺拷貝和深拷貝有什么區別?

    答:淺拷貝與深拷貝的區別,淺拷貝:如果對象中還包括著子對象,淺拷貝只能拷貝一份父對象的內存空間,而子對象則只是拷貝了其引用,值沒有進行拷貝。深拷貝則是涉及到這個對象當前所占的所有空間(值)都進行拷貝。

  61. Java反射機制有什么作用?

    答:反射可以讓程序在運行時具有檢測自己和獲取當前運行環境的能力。

    理解反射機制要了解靜態編譯和動態編譯,靜態編譯時在程序運行之前編譯時期就以及確定的,動態編譯則可以才程序運行期間,使程序自己改變自己的行為模式或邏輯,具有高度的靈活性。典型的編程設計模式動態代理就是在運行時期完成的編譯

  62. Java反射機制有什么優缺點?

    答:

    優點:增強程序靈活性和可拓展性,可幫助程序進行解耦合,提高自身的適應能力

    缺點:

    1、 性能問題。
    Java反射機制中包含了一些動態類型,所以Java虛擬機不能夠對這些動態代碼進行優化。因此,反射操作的效率要比正常操作效率低很多。我們應該避免在對性能要求很高的程序或經常被執行的代碼中使用反射。而且,如何使用反射決定了性能的高低。如果它作為程序中較少運行的部分,性能將不會成為一個問題。
    2、安全限制。
    使用反射通常需要程序的運行沒有安全方面的限制。如果一個程序對安全性提出要求,則最好不要使用反射。
    3、程序健壯性。
    反射允許代碼執行一些通常不被允許的操作,所以使用反射有可能會導致意想不到的后果。反射代碼破壞了Java程序結構的抽象性,所以當程序運行的平臺發生變化的時候,由于抽象的邏輯結構不能被識別,代碼產生的效果與之前會產生差異。

  63. 什么是宏變量和宏替換?

    答:引用用宏變量,系統會自動把宏變量替換成他所指向的地址的值

    String nb = "finaltest";
    String nb1 = "final";
    String nb2 = "test";
    final String nb11 = "final";
    final String nb22 = "test";
    String nb3 = "final" + "test";
    String nb4 = nb1 + nb2;
    String nb5 = nb11 + nb22;
    System.out.println(nb == nb3);
    System.out.println(nb == nb4);
    System.out.println(nb == nb5);
    
    true
    false
    true
        
    nb定義了finaltest,nb3定義了 “final” + “test”,初始編譯的時候nb3會確定初始值為finaltest(JVM在編譯時會對字面量的字符串進行優化),因此初始值與nb相等,所以會把nb3引用的地址指向nb引用的地址,所以nb與nb3相等。
        而nb11,nb22根據上面三條規則得知是宏變量,引用用宏變量,系統會自動把宏變量替換成他所指向的地址的值,所以nb11+nb22就會替換成finaltest,然后與nb3一樣,這就是宏替換。
    
  64. 什么是逃逸分析?

    答:在編程語言的編譯優化原理中,分析指針動態范圍的方法稱之為逃逸分析。通俗一點講,當一個對象的指針被多個方法或線程引用時,我們稱這個指針發生了逃逸。

    而用來分析這種逃逸現象的方法,就稱之為逃逸分析。全局變量賦值,方法返回值,實例引用傳遞。

    參考文章https://blog.csdn.net/u014352080/article/details/93165603

  65. 什么是偽共享?有什么解決方案?

    答:參考文章https://www.cnblogs.com/tong-yuan/p/FalseSharing.html

    什么是多線程環境下的偽共享(false sharing)?
    偽共享是多線程系統(每個處理器有自己的局部緩存)中一個眾所周知的性能問題。偽共享發生在不同處理器上的線程對變量的修改依賴于相同的緩存行,如下圖所示:

    小知識點:

    *1.*共享就是一個內存區域的數據被多個處理器訪問,偽共享就是不是真的共享。
    這里的共享這個概念是基于邏輯層面的。實際上偽共享與共享在cache line 上實際都是共享的。
    *
    2.*
    CPU訪問的數據都是從cache line 中讀取的。如果cpu 在cache 中找不到需要的變量,則稱緩存未命中。**

    未命中時,需要通過總線從內存中讀取進cache 中。每次讀取的內存大小就是一個cache line 的大小。

    3.****如果多個CPU訪問的不同內存變量被裝載到了同一個cache line 中,則從程序邏輯層上講,并沒有共享變量,
    但實際上在cache line 上他們是共享訪問的,這個就是典型的偽共享。

    4.****偽共享與共享 在 cache line 的層面上必須都是共享的。多個CPU對共享內存的訪問安全通過緩存一致性來保證。

    *5*.偽共享問題很難被發現,因為線程可能訪問完全不同的全局變量,內存中卻碰巧在很相近的位置上。如其他諸多的并發問題,避免偽共享的最基本方式是仔細審查代碼,根據緩存行來調整你的數據結構。

  66. Java 8新增了哪些特性?

    答:最核心的特性Lambda 表達式和函數式接口以及Stream API

  67. Java 8中的Lambda表達式有什么作用?

    答:Lambda 是一個匿名函數,可以把Lambda表達式理解為一段可以傳遞的代碼(將代碼像數據一樣傳遞)。可以寫出更加簡潔、靈活的代碼。作為一種更加緊湊的代碼風格,使java的語言表達能力得到了提升。

  68. Java 8中的Optional類有什么作用?

    答:以解決程序中常見的NullPointerException異常問題

  69. Java 8中的@Repeatable注解有什么作用?

    答:@Repeatable可以用來指示某種類型的注解是可以重復添加的

  70. Java 8中的方法引用是指什么?

    答:方法引用,如果函數式接口以及有具體實現了可以直接引用該方法。語法為ClassName::MethodName || ObjectName::實例方法名稱

  71. Java 8中的Stream有什么作用?

    答:提供了對集合計算的支持,集合負責存儲而Stream負責計算。它用于操作數據源所產生的序列,例如復雜的查找、過濾映射數據等操作

  72. Java 8中的函數式編程怎么用?

    答:函數與其他數據類型一樣,可以賦值給其他變量,也可以作為參數,也可以作為返回值

    • 代碼簡潔,開發快速
    • 易于理解,降低風險
    • 易于并行
    • 延遲執行
  73. 如何獲取一個Stream流對象?

    答:

    • 數組獲取Stream:Arrays.stream(數組對象)
    • 集合獲取Stream:集合對象.stream()
    • 值獲取Stream:Stream.of(值...)
  74. 什么是序列化,怎么序列化,為什么序列化,反序列化會遇到什么問題,如何解決。

    答:序列化是將內存中存儲的對象數據轉換為可斷電存儲或網絡傳輸的二進制數據。序列化的方式很多,首先將需要序列化的類實現Serializable常見的JDK提供的ObjectOutPutStream或者JSON格式序列化等等。反序列可能會遇到反序列化后的類版本不一致問題,需要保證序列化和反序列化的版本一直

本站僅提供存儲服務,所有內容均由用戶發布,如發現有害或侵權內容,請點擊舉報
打開APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
Java性能的優化(五)
JAVA面試700問(一) | 并發編程網
Java對象的序列化和反序列化實踐
Java初級工程師面試題精選2
java常用的關鍵字
新手必備Java快速掃盲指南
更多類似文章 >>
生活服務
分享 收藏 導長圖 關注 下載文章
綁定賬號成功
后續可登錄賬號暢享VIP特權!
如果VIP功能使用有故障,
可點擊這里聯系客服!

聯系客服

主站蜘蛛池模板: 汉中市| 绥江县| 永新县| 托克逊县| 张家港市| SHOW| 饶平县| 乐业县| 双城市| 岚皋县| 邵东县| 黄龙县| 原平市| 名山县| 滦南县| 阳谷县| 江孜县| 孟州市| 聂荣县| 阳原县| 封丘县| 兴宁市| 平安县| 壶关县| 清丰县| 海南省| 沁源县| 鄂伦春自治旗| 黎平县| 佛学| 静海县| 文水县| 卓资县| 虹口区| 都昌县| 兴宁市| 安丘市| 商城县| 宿松县| 武平县| 文登市|