小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

Java開發(fā)工程師最新面試題庫(kù)系列——Java基礎(chǔ)部分(附答案)

 新進(jìn)小設(shè)計(jì) 2021-05-03

JAVA基礎(chǔ)

如果你有更好的想法請(qǐng)?jiān)谠u(píng)論區(qū)留下您的答案,一起交流討論

  1. 面向?qū)ο笥心男┨卣鳎?/p>

    答:繼承、封裝、多態(tài)

  2. JDK與JRE的區(qū)別是什么?

    答:JDK是java開發(fā)時(shí)所需環(huán)境,它包含了Java開發(fā)時(shí)需要用到的API,JRE是Java的運(yùn)行時(shí)環(huán)境,JDK包含了JRE,他們是包含關(guān)系

  3. Java有哪幾種基本數(shù)據(jù)類型?

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

  4. == 和equals比較有什么區(qū)別?

    答:是Java中的操作符,equals是Java中Object對(duì)象提供的對(duì)象比較Api。它們的區(qū)別是比較的是左右兩邊對(duì)象的內(nèi)存地址,而equals比較的是左右對(duì)象的值

  5. public,private,protected,默認(rèn)的區(qū)別什么?

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

  6. short s1=1; s1+=1;有錯(cuò)嗎? s1=s1+1; 有錯(cuò)嗎?

    答:short在和int類型進(jìn)行計(jì)算的時(shí)候會(huì)轉(zhuǎn)換為int類型,原因是Java中精度小于int的數(shù)值運(yùn)算的時(shí)候都回被自動(dòng)轉(zhuǎn)換為int后進(jìn)行計(jì)算。計(jì)算后的結(jié)果也是int,再將int類型賦值給short類型當(dāng)然會(huì)報(bào)錯(cuò),所以s1=s1+1是錯(cuò)誤的,然而s1+=1是java底層采用了編譯語(yǔ)法糖的形式完成的轉(zhuǎn)換,在編譯后依然是轉(zhuǎn)換為int計(jì)算只不過(guò)最終做了一次強(qiáng)轉(zhuǎn)

  7. float f = 1.9; 有錯(cuò)嗎?

    答:有錯(cuò),因?yàn)樵贘ava中字面量的小數(shù)指的是double類型,double為8個(gè)字節(jié)float為4個(gè)字節(jié),無(wú)法完成自動(dòng)轉(zhuǎn)換。如果需要將字面量的小數(shù)轉(zhuǎn)換為float類型需要在小數(shù)后面加f或者F

  8. &和&&有什么區(qū)別?

    答:前者是與符號(hào),后者是短路與符號(hào)。前者除了可以做邏輯運(yùn)算和可以做位運(yùn)算稱為“按位與”,后者只能做邏輯運(yùn)算,其次再邏輯運(yùn)算中,這兩個(gè)符號(hào)都需要左右兩側(cè)表達(dá)式為true時(shí),最后結(jié)果才為true

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

    答:2 << 3

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

    答:值傳遞傳遞的是變量中的數(shù)據(jù),應(yīng)用傳遞則是傳遞變量的引用而不是值

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

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

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

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

  13. final關(guān)鍵字有哪些用法?

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

  14. final、finally、finalize有什么區(qū)別?

    答:除了名稱相像,都比相同。final屬于java的修飾符,finally是結(jié)合Java異常體現(xiàn)中的Try一起使用的標(biāo)識(shí)符用來(lái)關(guān)閉一些資源,finalize是Object根類中的一個(gè)方法,是對(duì)象被回收之前執(zhí)行的方法。

  15. void和Void有什么區(qū)別?

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

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

    答:2的8次方,且減去正數(shù)的零

  17. char類型可以存儲(chǔ)中文漢字嗎?

    答:可以,char默認(rèn)為2個(gè)字節(jié),不過(guò)char采用的是UTF-16BE的編碼集,且該編碼集支持中文,char可以動(dòng)態(tài)的更具字符內(nèi)容改變字節(jié),最大可以到4

  18. 重載和重寫有什么區(qū)別?

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

  19. 構(gòu)造器可以被重寫和重載嗎?

    答:構(gòu)造器可以被重載,但是不能被重寫,因?yàn)闃?gòu)造器不能被繼承

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

    答:用于檢測(cè)表達(dá)式或方法的最終結(jié)果是否符合預(yù)期

  21. Error和Exception有哪些區(qū)別?

    答:Error是系統(tǒng)錯(cuò)誤,一般由于系統(tǒng)原因或JVM內(nèi)部錯(cuò)誤引起,無(wú)法被程序捕獲處理,Exception是程序異常,其中又分編譯時(shí)(檢查時(shí))異常和運(yùn)行時(shí)異常,可以被程序捕獲處理,一般我們?cè)陂_發(fā)中針對(duì)運(yùn)行時(shí)異常進(jìn)行處理。

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

    答:NullPointException空指針異常、Arithmeticexception算數(shù)異常、ClassCastException類型轉(zhuǎn)換異常、ClassNotFoundException類為找到異常、illegalargumentexception方法參數(shù)錯(cuò)誤異常、ArrayIndexOfOutBoundsException數(shù)組索引越界異常

  23. Java中常見的運(yùn)行時(shí)異常有哪些?

    答:NoSuchMethodError 為找到方法異常(反射調(diào)用方法時(shí)),NumberFormatException 數(shù)值轉(zhuǎn)換異常,NullPointException空指針異常、Arithmeticexception算數(shù)異常、ClassCastException類型轉(zhuǎn)換異常

  24. 運(yùn)行時(shí)異常和受檢異常有什么區(qū)別?

    答:

    運(yùn)行時(shí)異常包括 RuntimeException 類及其子類,表示 JVM 在運(yùn)行期間可能出現(xiàn)的異常。Java 編譯器不會(huì)檢查運(yùn)行時(shí)異常。

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

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

  25. 什么時(shí)候會(huì)發(fā)生空指針異常?

    答:對(duì)值為空的變量進(jìn)行操作時(shí)

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

    答:對(duì)值為空的變量進(jìn)行操作時(shí)先判斷是否為空

  27. throw和throws有什么區(qū)別?

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

  28. try里面return,finally還會(huì)執(zhí)行嗎?

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

  29. int和Integer有什么區(qū)別?

    答:int是java的基本數(shù)據(jù)類型,Integer是Java的引用數(shù)據(jù)類型。Integer是int的包裝類,它提供了對(duì)int的轉(zhuǎn)換和計(jì)算等API,操作起來(lái)更加方便

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

    答:包裝類型是對(duì)基本數(shù)據(jù)類型的封裝,底層其實(shí)就是對(duì)基本數(shù)據(jù)類型的操作提供了API和語(yǔ)法糖

  31. 什么是自動(dòng)裝箱和拆箱?

    答:基本數(shù)據(jù)類型轉(zhuǎn)引用數(shù)據(jù)類型為自動(dòng)拆箱,反之為自動(dòng)裝箱

  32. 你怎么理解Java中的自動(dòng)類型轉(zhuǎn)換和強(qiáng)制類型轉(zhuǎn)換?

    答:小轉(zhuǎn)大自動(dòng)轉(zhuǎn)換,拓展變量的內(nèi)存字節(jié)。大轉(zhuǎn)小強(qiáng)制轉(zhuǎn)換,縮小內(nèi)存字節(jié)損失精度

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

    答:語(yǔ)法糖

  34. 你怎么理解強(qiáng)、軟、弱、虛引用?

    答:這里寫圖片描述

  35. switch是否能用在long上?

    答:可以,switch支持int、byte、short、char以及對(duì)應(yīng)的包裝類,和String類型

  36. switch case支持哪幾種數(shù)據(jù)類型?

    答:如上

  37. String的底層實(shí)現(xiàn)是怎樣的?

    答:char數(shù)組,以及字符串常量池

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

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

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

    答:因?yàn)槿绻?號(hào)拼接字符串JVM編譯時(shí)會(huì)進(jìn)行優(yōu)化,轉(zhuǎn)變?yōu)镾tringBuilder拼接。單個(gè)表達(dá)式使用問(wèn)題不大,但是如果是多個(gè)表達(dá)式或者在循環(huán)內(nèi)使用會(huì)頻繁創(chuàng)建StringBuilder對(duì)象大大降低性能

  40. StringBuffer和StringBuilder有什么區(qū)別?

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

  41. StringJoiner有什么用?

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

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

    答:抽象類被abstract所修飾,

  43. 靜態(tài)內(nèi)部類和普通內(nèi)部類有什么區(qū)別?

    答:普通內(nèi)部類持有外部外部類的應(yīng)用,可以調(diào)用外部類的屬性及方法,而靜態(tài)內(nèi)部類沒有持有外部?jī)?nèi)引用,無(wú)法調(diào)用外部?jī)?nèi)的方法及屬性。靜態(tài)內(nèi)部類可以有靜態(tài)成員(方法,屬性),而非靜態(tài)內(nèi)部類則不能有靜態(tài)成 員(方法,屬性)。 非靜態(tài)內(nèi)部類能夠訪問(wèn)外部類的靜態(tài)和非靜態(tài)成員。靜態(tài)內(nèi)部類不能訪問(wèn)外 部類的非靜態(tài)成員,只能訪問(wèn)外部類的靜態(tài)成員。

    實(shí)例化方式不同:

    1. 靜態(tài)內(nèi)部類:不依賴于外部類的實(shí)例,直接實(shí)例化內(nèi)部類對(duì)象
    2. 非靜態(tài)內(nèi)部類:通過(guò)外部類的對(duì)象實(shí)例生成內(nèi)部類對(duì)象
  44. 靜態(tài)方法可以直接調(diào)用非靜態(tài)方法嗎?為什么?

    答:不能,因?yàn)殪o態(tài)方法的加載順序優(yōu)先于非靜態(tài)方法,且靜態(tài)方法屬于類,無(wú)需對(duì)象實(shí)例,非靜態(tài)方法則需要類的實(shí)例才能調(diào)用

  45. 靜態(tài)變量和實(shí)力變量有什么區(qū)別?

    答:靜態(tài)變量屬于類,無(wú)需創(chuàng)建對(duì)象通過(guò)類名即可調(diào)用,而實(shí)例變量需要類創(chuàng)建實(shí)例才可以調(diào)用。加載角度而言只要JVM加載了靜態(tài)變量所處的類,靜態(tài)變量就以及可以使用,為分配了空間。而實(shí)例變量需要?jiǎng)?chuàng)建對(duì)象之后才會(huì)為其分配空間

  46. 內(nèi)部類可以訪問(wèn)其外部類的成員嗎?

    答:非靜態(tài)內(nèi)部類可以,因?yàn)樗钟姓咄獠績(jī)?nèi)的引用。

  47. 接口和抽象類有什么區(qū)別?

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

  48. 接口里面可以寫方法實(shí)現(xiàn)嗎?

    答:可以,jdk1.8之后可以寫接口的默認(rèn)方法實(shí)現(xiàn)

  49. Java中的UUID是什么?

    答:生成一串隨機(jī)的數(shù)字,它保證對(duì)在同一時(shí)空中的所有機(jī)器都是唯一的

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

    答:如下

    img

    img

  51. hashCode有什么作用?

    答:hashcode在java中用于表示對(duì)象的唯一碼。hashcode也用在Hash數(shù)據(jù)結(jié)構(gòu)中,用來(lái)計(jì)算對(duì)象存放在Hash中的位置(存儲(chǔ)地址)

  52. hashCode和identityHashCode的區(qū)別?

    答:

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

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

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

    答:

    @Target:描述了注解修飾的對(duì)象范圍

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

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

    @Retention:表示注解的運(yùn)行時(shí)期范圍

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

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

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

    答:

    • ? --不確定的Java類型,是一個(gè)通配符泛型
    • T --表示確定的Java類型
    • K、V --Java中的鍵值對(duì)key、value
    • E --Element (在集合中使用,因?yàn)榧现写娣诺氖窃?,也表示Collection容器中的類型)
      Java源碼中的Class代表這個(gè)類型所對(duì)應(yīng)的類,而Class<?>表示類型不確定的類。
  56. Java金額計(jì)算怎么避免精度丟失?

    答:使用BigDecimal進(jìn)行與金錢相關(guān)的計(jì)算

  57. Java語(yǔ)法糖是什么意思?

    答:通過(guò)提供簡(jiǎn)單的編寫方式在編譯時(shí)完成對(duì)復(fù)雜操作的轉(zhuǎn)換。通常是指Java中的簡(jiǎn)單語(yǔ)法,在編譯時(shí)期還原成基礎(chǔ)語(yǔ)法。

  58. transient關(guān)鍵字有什么作用?

    答:將不需要序列化的屬性前添加關(guān)鍵字transient,序列化對(duì)象的時(shí)候,這個(gè)屬性就不會(huì)被序列化

  59. 如何實(shí)現(xiàn)對(duì)象克隆?

    答:Java對(duì)象克隆又分深拷貝和淺拷貝,淺拷貝調(diào)用Object跟對(duì)象繼承下來(lái)的clone,深拷貝可以借助SpringFramework提供的BeanUtils工具或者通過(guò)Java的序列化與反序列化實(shí)現(xiàn)。

  60. 對(duì)象克隆淺拷貝和深拷貝有什么區(qū)別?

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

  61. Java反射機(jī)制有什么作用?

    答:反射可以讓程序在運(yùn)行時(shí)具有檢測(cè)自己和獲取當(dāng)前運(yùn)行環(huán)境的能力。

    理解反射機(jī)制要了解靜態(tài)編譯和動(dòng)態(tài)編譯,靜態(tài)編譯時(shí)在程序運(yùn)行之前編譯時(shí)期就以及確定的,動(dòng)態(tài)編譯則可以才程序運(yùn)行期間,使程序自己改變自己的行為模式或邏輯,具有高度的靈活性。典型的編程設(shè)計(jì)模式動(dòng)態(tài)代理就是在運(yùn)行時(shí)期完成的編譯

  62. Java反射機(jī)制有什么優(yōu)缺點(diǎn)?

    答:

    優(yōu)點(diǎn):增強(qiáng)程序靈活性和可拓展性,可幫助程序進(jìn)行解耦合,提高自身的適應(yīng)能力

    缺點(diǎn):

    1、 性能問(wèn)題。
    Java反射機(jī)制中包含了一些動(dòng)態(tài)類型,所以Java虛擬機(jī)不能夠?qū)@些動(dòng)態(tài)代碼進(jìn)行優(yōu)化。因此,反射操作的效率要比正常操作效率低很多。我們應(yīng)該避免在對(duì)性能要求很高的程序或經(jīng)常被執(zhí)行的代碼中使用反射。而且,如何使用反射決定了性能的高低。如果它作為程序中較少運(yùn)行的部分,性能將不會(huì)成為一個(gè)問(wèn)題。
    2、安全限制。
    使用反射通常需要程序的運(yùn)行沒有安全方面的限制。如果一個(gè)程序?qū)Π踩蕴岢鲆螅瑒t最好不要使用反射。
    3、程序健壯性。
    反射允許代碼執(zhí)行一些通常不被允許的操作,所以使用反射有可能會(huì)導(dǎo)致意想不到的后果。反射代碼破壞了Java程序結(jié)構(gòu)的抽象性,所以當(dāng)程序運(yùn)行的平臺(tái)發(fā)生變化的時(shí)候,由于抽象的邏輯結(jié)構(gòu)不能被識(shí)別,代碼產(chǎn)生的效果與之前會(huì)產(chǎn)生差異。

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

    答:引用用宏變量,系統(tǒng)會(huì)自動(dòng)把宏變量替換成他所指向的地址的值

    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”,初始編譯的時(shí)候nb3會(huì)確定初始值為finaltest(JVM在編譯時(shí)會(huì)對(duì)字面量的字符串進(jìn)行優(yōu)化),因此初始值與nb相等,所以會(huì)把nb3引用的地址指向nb引用的地址,所以nb與nb3相等。
        而nb11,nb22根據(jù)上面三條規(guī)則得知是宏變量,引用用宏變量,系統(tǒng)會(huì)自動(dòng)把宏變量替換成他所指向的地址的值,所以nb11+nb22就會(huì)替換成finaltest,然后與nb3一樣,這就是宏替換。
    
  64. 什么是逃逸分析?

    答:在編程語(yǔ)言的編譯優(yōu)化原理中,分析指針動(dòng)態(tài)范圍的方法稱之為逃逸分析。通俗一點(diǎn)講,當(dāng)一個(gè)對(duì)象的指針被多個(gè)方法或線程引用時(shí),我們稱這個(gè)指針發(fā)生了逃逸。

    而用來(lái)分析這種逃逸現(xiàn)象的方法,就稱之為逃逸分析。全局變量賦值,方法返回值,實(shí)例引用傳遞。

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

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

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

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

    小知識(shí)點(diǎn):

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

    未命中時(shí),需要通過(guò)總線從內(nèi)存中讀取進(jìn)cache 中。每次讀取的內(nèi)存大小就是一個(gè)cache line 的大小。

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

    4.****偽共享與共享 在 cache line 的層面上必須都是共享的。多個(gè)CPU對(duì)共享內(nèi)存的訪問(wèn)安全通過(guò)緩存一致性來(lái)保證。

    *5*.偽共享問(wèn)題很難被發(fā)現(xiàn),因?yàn)榫€程可能訪問(wèn)完全不同的全局變量,內(nèi)存中卻碰巧在很相近的位置上。如其他諸多的并發(fā)問(wèn)題,避免偽共享的最基本方式是仔細(xì)審查代碼,根據(jù)緩存行來(lái)調(diào)整你的數(shù)據(jù)結(jié)構(gòu)。

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

    答:最核心的特性Lambda 表達(dá)式和函數(shù)式接口以及Stream API

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

    答:Lambda 是一個(gè)匿名函數(shù),可以把Lambda表達(dá)式理解為一段可以傳遞的代碼(將代碼像數(shù)據(jù)一樣傳遞)??梢詫懗龈雍?jiǎn)潔、靈活的代碼。作為一種更加緊湊的代碼風(fēng)格,使java的語(yǔ)言表達(dá)能力得到了提升。

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

    答:以解決程序中常見的NullPointerException異常問(wèn)題

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

    答:@Repeatable可以用來(lái)指示某種類型的注解是可以重復(fù)添加的

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

    答:方法引用,如果函數(shù)式接口以及有具體實(shí)現(xiàn)了可以直接引用該方法。語(yǔ)法為ClassName::MethodName || ObjectName::實(shí)例方法名稱

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

    答:提供了對(duì)集合計(jì)算的支持,集合負(fù)責(zé)存儲(chǔ)而Stream負(fù)責(zé)計(jì)算。它用于操作數(shù)據(jù)源所產(chǎn)生的序列,例如復(fù)雜的查找、過(guò)濾映射數(shù)據(jù)等操作

  72. Java 8中的函數(shù)式編程怎么用?

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

    • 代碼簡(jiǎn)潔,開發(fā)快速
    • 易于理解,降低風(fēng)險(xiǎn)
    • 易于并行
    • 延遲執(zhí)行
  73. 如何獲取一個(gè)Stream流對(duì)象?

    答:

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

    答:序列化是將內(nèi)存中存儲(chǔ)的對(duì)象數(shù)據(jù)轉(zhuǎn)換為可斷電存儲(chǔ)或網(wǎng)絡(luò)傳輸?shù)亩M(jìn)制數(shù)據(jù)。序列化的方式很多,首先將需要序列化的類實(shí)現(xiàn)Serializable常見的JDK提供的ObjectOutPutStream或者JSON格式序列化等等。反序列可能會(huì)遇到反序列化后的類版本不一致問(wèn)題,需要保證序列化和反序列化的版本一直

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多