-
面向?qū)ο笥心男┨卣鳎?/p>
答:繼承、封裝、多態(tài)
-
JDK與JRE的區(qū)別是什么?
答:JDK是java開發(fā)時(shí)所需環(huán)境,它包含了Java開發(fā)時(shí)需要用到的API,JRE是Java的運(yùn)行時(shí)環(huán)境,JDK包含了JRE,他們是包含關(guān)系
-
Java有哪幾種基本數(shù)據(jù)類型?
答:8種,分別是int、byte、short、long、double、flot、char、boolean
-
== 和equals比較有什么區(qū)別?
答:是Java中的操作符,equals是Java中Object對(duì)象提供的對(duì)象比較Api。它們的區(qū)別是比較的是左右兩邊對(duì)象的內(nèi)存地址,而equals比較的是左右對(duì)象的值
-
public,private,protected,默認(rèn)的區(qū)別什么?
答:它們是java中的權(quán)限修飾符,public可以在任何地方訪問,private僅僅只能在本類中訪問,protected可以在本類以及本類的子類中訪問,默認(rèn)則代表可以在本包中訪問
-
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底層采用了編譯語法糖的形式完成的轉(zhuǎn)換,在編譯后依然是轉(zhuǎn)換為int計(jì)算只不過最終做了一次強(qiáng)轉(zhuǎn)
-
float f = 1.9; 有錯(cuò)嗎?
答:有錯(cuò),因?yàn)樵贘ava中字面量的小數(shù)指的是double類型,double為8個(gè)字節(jié)float為4個(gè)字節(jié),無法完成自動(dòng)轉(zhuǎn)換。如果需要將字面量的小數(shù)轉(zhuǎn)換為float類型需要在小數(shù)后面加f或者F
-
&和&&有什么區(qū)別?
答:前者是與符號(hào),后者是短路與符號(hào)。前者除了可以做邏輯運(yùn)算和可以做位運(yùn)算稱為“按位與”,后者只能做邏輯運(yùn)算,其次再邏輯運(yùn)算中,這兩個(gè)符號(hào)都需要左右兩側(cè)表達(dá)式為true時(shí),最后結(jié)果才為true
-
2*8最有效率的計(jì)算方法是什么?
答:2 << 3
-
怎么理解值傳遞和引用傳遞?
答:值傳遞傳遞的是變量中的數(shù)據(jù),應(yīng)用傳遞則是傳遞變量的引用而不是值
-
Java到底是值傳遞還是引用傳遞?
答:Java中8種基本數(shù)據(jù)類型傳遞的是值,而引用數(shù)據(jù)類型傳遞的是引用
-
一個(gè)".java"源文件的類有什么限制?
答:最多只能有一個(gè)public static void mian方法,最少有一個(gè)類
-
final關(guān)鍵字有哪些用法?
答:修飾類:最終類,不可被子類繼承,修飾方法:最終方法,不可被子類進(jìn)行方法覆蓋,修飾變量:常量,必須在聲明時(shí)賦值,且之后的程序中不可改變。
-
final、finally、finalize有什么區(qū)別?
答:除了名稱相像,都比相同。final屬于java的修飾符,finally是結(jié)合Java異常體現(xiàn)中的Try一起使用的標(biāo)識(shí)符用來關(guān)閉一些資源,finalize是Object根類中的一個(gè)方法,是對(duì)象被回收之前執(zhí)行的方法。
-
void和Void有什么區(qū)別?
答:void是關(guān)鍵字在java中代表返回值為空,Void是類名
-
為什么byte的取值范圍為-128~127?
答:2的8次方,且減去正數(shù)的零
-
char類型可以存儲(chǔ)中文漢字嗎?
答:可以,char默認(rèn)為2個(gè)字節(jié),不過char采用的是UTF-16BE的編碼集,且該編碼集支持中文,char可以動(dòng)態(tài)的更具字符內(nèi)容改變字節(jié),最大可以到4
-
重載和重寫有什么區(qū)別?
答:重載是在同一類中,滿足重載需要方法名相同,參數(shù)列表不同,與返回值和訪問修飾符無關(guān)。重寫是在繼承關(guān)系中,子類對(duì)父類方法的覆蓋,需要滿足“一同兩小一大”(方法名相同,返回值類型小于等于父類方法,聲明拋出異常小于等于父類方法,訪問權(quán)限修飾符大于等于父類方法)
-
構(gòu)造器可以被重寫和重載嗎?
答:構(gòu)造器可以被重載,但是不能被重寫,因?yàn)闃?gòu)造器不能被繼承
-
Java中的斷言(assert)是什么?
答:用于檢測(cè)表達(dá)式或方法的最終結(jié)果是否符合預(yù)期
-
Error和Exception有哪些區(qū)別?
答:Error是系統(tǒng)錯(cuò)誤,一般由于系統(tǒng)原因或JVM內(nèi)部錯(cuò)誤引起,無法被程序捕獲處理,Exception是程序異常,其中又分編譯時(shí)(檢查時(shí))異常和運(yùn)行時(shí)異常,可以被程序捕獲處理,一般我們?cè)陂_發(fā)中針對(duì)運(yùn)行時(shí)異常進(jìn)行處理。
-
Java中常見的異常有哪些?
答:NullPointException空指針異常、Arithmeticexception算數(shù)異常、ClassCastException類型轉(zhuǎn)換異常、ClassNotFoundException類為找到異常、illegalargumentexception方法參數(shù)錯(cuò)誤異常、ArrayIndexOfOutBoundsException數(shù)組索引越界異常
-
Java中常見的運(yùn)行時(shí)異常有哪些?
答:NoSuchMethodError 為找到方法異常(反射調(diào)用方法時(shí)),NumberFormatException 數(shù)值轉(zhuǎn)換異常,NullPointException空指針異常、Arithmeticexception算數(shù)異常、ClassCastException類型轉(zhuǎn)換異常
-
運(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)。一般來講,如果沒有特殊的要求,我們建議使用RuntimeException異常。
-
什么時(shí)候會(huì)發(fā)生空指針異常?
答:對(duì)值為空的變量進(jìn)行操作時(shí)
-
你知道有哪些避免空指針異常的方法?
答:對(duì)值為空的變量進(jìn)行操作時(shí)先判斷是否為空
-
throw和throws有什么區(qū)別?
答:throw用于在方法中拋出異常,throws寫在方法名稱后面,用于聲明拋出的異常類型
-
try里面return,finally還會(huì)執(zhí)行嗎?
答:會(huì)的,除了System.exit(0)finally都會(huì)執(zhí)行
-
int和Integer有什么區(qū)別?
答:int是java的基本數(shù)據(jù)類型,Integer是Java的引用數(shù)據(jù)類型。Integer是int的包裝類,它提供了對(duì)int的轉(zhuǎn)換和計(jì)算等API,操作起來更加方便
-
什么是包裝類型?有什么用?
答:包裝類型是對(duì)基本數(shù)據(jù)類型的封裝,底層其實(shí)就是對(duì)基本數(shù)據(jù)類型的操作提供了API和語法糖
-
什么是自動(dòng)裝箱和拆箱?
答:基本數(shù)據(jù)類型轉(zhuǎn)引用數(shù)據(jù)類型為自動(dòng)拆箱,反之為自動(dòng)裝箱
-
你怎么理解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é)損失精度
-
你怎么理解Java中的類型提升?
答:語法糖
-
你怎么理解強(qiáng)、軟、弱、虛引用?
答:
-
switch是否能用在long上?
答:可以,switch支持int、byte、short、char以及對(duì)應(yīng)的包裝類,和String類型
-
switch case支持哪幾種數(shù)據(jù)類型?
答:如上
-
String的底層實(shí)現(xiàn)是怎樣的?
答:char數(shù)組,以及字符串常量池
-
String是可變的嗎?為什么?
答:不可變,java中的字面量字符串都存放在字符串常量池中,無法改變,只能引用
-
為什么不能用 + 拼接字符串?
答:因?yàn)槿绻?號(hào)拼接字符串JVM編譯時(shí)會(huì)進(jìn)行優(yōu)化,轉(zhuǎn)變?yōu)镾tringBuilder拼接。單個(gè)表達(dá)式使用問題不大,但是如果是多個(gè)表達(dá)式或者在循環(huán)內(nèi)使用會(huì)頻繁創(chuàng)建StringBuilder對(duì)象大大降低性能
-
StringBuffer和StringBuilder有什么區(qū)別?
答:前者線程安全效率低,后者線程不安全效率高,
-
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'
-
普通類和抽象類有什么區(qū)別?
答:抽象類被abstract所修飾,
-
靜態(tài)內(nèi)部類和普通內(nèi)部類有什么區(qū)別?
答:普通內(nèi)部類持有外部外部類的應(yīng)用,可以調(diào)用外部類的屬性及方法,而靜態(tài)內(nèi)部類沒有持有外部內(nèi)引用,無法調(diào)用外部內(nèi)的方法及屬性。靜態(tài)內(nèi)部類可以有靜態(tài)成員(方法,屬性),而非靜態(tài)內(nèi)部類則不能有靜態(tài)成 員(方法,屬性)。 非靜態(tài)內(nèi)部類能夠訪問外部類的靜態(tài)和非靜態(tài)成員。靜態(tài)內(nèi)部類不能訪問外 部類的非靜態(tài)成員,只能訪問外部類的靜態(tài)成員。
實(shí)例化方式不同:
- 靜態(tài)內(nèi)部類:不依賴于外部類的實(shí)例,直接實(shí)例化內(nèi)部類對(duì)象
- 非靜態(tài)內(nèi)部類:通過外部類的對(duì)象實(shí)例生成內(nèi)部類對(duì)象
-
靜態(tài)方法可以直接調(diào)用非靜態(tài)方法嗎?為什么?
答:不能,因?yàn)殪o態(tài)方法的加載順序優(yōu)先于非靜態(tài)方法,且靜態(tài)方法屬于類,無需對(duì)象實(shí)例,非靜態(tài)方法則需要類的實(shí)例才能調(diào)用
-
靜態(tài)變量和實(shí)力變量有什么區(qū)別?
答:靜態(tài)變量屬于類,無需創(chuàng)建對(duì)象通過類名即可調(diào)用,而實(shí)例變量需要類創(chuàng)建實(shí)例才可以調(diào)用。加載角度而言只要JVM加載了靜態(tài)變量所處的類,靜態(tài)變量就以及可以使用,為分配了空間。而實(shí)例變量需要?jiǎng)?chuàng)建對(duì)象之后才會(huì)為其分配空間
-
內(nèi)部類可以訪問其外部類的成員嗎?
答:非靜態(tài)內(nèi)部類可以,因?yàn)樗钟姓咄獠績?nèi)的引用。
-
接口和抽象類有什么區(qū)別?
答:接口沒有構(gòu)造方法,抽象類有。抽象類中可以有普通成員變量;接口中沒有普通成員變量。抽象類中可以包含非抽象普通方法;接口中的所有方法必須都是抽象的,不能有非抽象的方法。一個(gè)類可以實(shí)現(xiàn)多個(gè)接口,用逗號(hào)隔開,但只能繼承一個(gè)抽象類;接口不可以實(shí)現(xiàn)接口,但可以繼承接口,并且可以繼承多個(gè)接口,用逗號(hào)隔開。
-
接口里面可以寫方法實(shí)現(xiàn)嗎?
答:可以,jdk1.8之后可以寫接口的默認(rèn)方法實(shí)現(xiàn)
-
Java中的UUID是什么?
答:生成一串隨機(jī)的數(shù)字,它保證對(duì)在同一時(shí)空中的所有機(jī)器都是唯一的
-
Java類初始化順序是怎樣的?
答:如下


-
hashCode有什么作用?
答:hashcode在java中用于表示對(duì)象的唯一碼。hashcode也用在Hash數(shù)據(jù)結(jié)構(gòu)中,用來計(jì)算對(duì)象存放在Hash中的位置(存儲(chǔ)地址)
-
hashCode和identityHashCode的區(qū)別?
答:
- Object類中的hashCode方法會(huì)返回一個(gè)hash碼,只有指向同一個(gè)對(duì)象的引用變量調(diào)用才會(huì)返回相同值,而String類中放寬了要求,對(duì)象里的值相等也返回相同值
- identityHashCode方法是System類中的方法,調(diào)用該方法時(shí),不管類中是否重寫了Object類中的hashCode方法,都執(zhí)行Object類中的hashCode方法,返回一個(gè)hashCode值。所以只有指向同一個(gè)對(duì)象的引用變量調(diào)用才會(huì)返回相同值
-
什么是Hash沖突?
答:兩個(gè)對(duì)象都放入同一個(gè)hash容器中,且計(jì)算出的hash值都相同。也稱為hash碰撞,此時(shí)的解決辦法是再hash
-
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)行期也保留注釋,因此可以通過反射機(jī)制讀取注解的信息
@Documented:使用 javadoc 工具為類生成幫助文檔時(shí)是否要保留其注解信息
-
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<?>表示類型不確定的類。
-
Java金額計(jì)算怎么避免精度丟失?
答:使用BigDecimal進(jìn)行與金錢相關(guān)的計(jì)算
-
Java語法糖是什么意思?
答:通過提供簡單的編寫方式在編譯時(shí)完成對(duì)復(fù)雜操作的轉(zhuǎn)換。通常是指Java中的簡單語法,在編譯時(shí)期還原成基礎(chǔ)語法。
-
transient關(guān)鍵字有什么作用?
答:將不需要序列化的屬性前添加關(guān)鍵字transient,序列化對(duì)象的時(shí)候,這個(gè)屬性就不會(huì)被序列化
-
如何實(shí)現(xiàn)對(duì)象克???
答:Java對(duì)象克隆又分深拷貝和淺拷貝,淺拷貝調(diào)用Object跟對(duì)象繼承下來的clone,深拷貝可以借助SpringFramework提供的BeanUtils工具或者通過Java的序列化與反序列化實(shí)現(xiàn)。
-
對(duì)象克隆淺拷貝和深拷貝有什么區(qū)別?
答:淺拷貝與深拷貝的區(qū)別,淺拷貝:如果對(duì)象中還包括著子對(duì)象,淺拷貝只能拷貝一份父對(duì)象的內(nèi)存空間,而子對(duì)象則只是拷貝了其引用,值沒有進(jìn)行拷貝。深拷貝則是涉及到這個(gè)對(duì)象當(dāng)前所占的所有空間(值)都進(jìn)行拷貝。
-
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í)期完成的編譯
-
Java反射機(jī)制有什么優(yōu)缺點(diǎn)?
答:
優(yōu)點(diǎn):增強(qiáng)程序靈活性和可拓展性,可幫助程序進(jìn)行解耦合,提高自身的適應(yīng)能力
缺點(diǎn):
1、 性能問題。
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è)問題。
2、安全限制。
使用反射通常需要程序的運(yùn)行沒有安全方面的限制。如果一個(gè)程序?qū)Π踩蕴岢鲆?,則最好不要使用反射。
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)生差異。
-
什么是宏變量和宏替換?
答:引用用宏變量,系統(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一樣,這就是宏替換。
-
什么是逃逸分析?
答:在編程語言的編譯優(yōu)化原理中,分析指針動(dòng)態(tài)范圍的方法稱之為逃逸分析。通俗一點(diǎn)講,當(dāng)一個(gè)對(duì)象的指針被多個(gè)方法或線程引用時(shí),我們稱這個(gè)指針發(fā)生了逃逸。
而用來分析這種逃逸現(xiàn)象的方法,就稱之為逃逸分析。全局變量賦值,方法返回值,實(shí)例引用傳遞。
參考文章https://blog.csdn.net/u014352080/article/details/93165603
-
什么是偽共享?有什么解決方案?
答:參考文章https://www.cnblogs.com/tong-yuan/p/FalseSharing.html
什么是多線程環(huán)境下的偽共享(false sharing)?
偽共享是多線程系統(tǒng)(每個(gè)處理器有自己的局部緩存)中一個(gè)眾所周知的性能問題。偽共享發(fā)生在不同處理器上的線程對(duì)變量的修改依賴于相同的緩存行,如下圖所示:
小知識(shí)點(diǎn):
*1.*共享就是一個(gè)內(nèi)存區(qū)域的數(shù)據(jù)被多個(gè)處理器訪問,偽共享就是不是真的共享。
這里的共享這個(gè)概念是基于邏輯層面的。實(shí)際上偽共享與共享在cache line 上實(shí)際都是共享的。
*2.*CPU訪問的數(shù)據(jù)都是從cache line 中讀取的。如果cpu 在cache 中找不到需要的變量,則稱緩存未命中。**
未命中時(shí),需要通過總線從內(nèi)存中讀取進(jìn)cache 中。每次讀取的內(nèi)存大小就是一個(gè)cache line 的大小。
3.****如果多個(gè)CPU訪問的不同內(nèi)存變量被裝載到了同一個(gè)cache line 中,則從程序邏輯層上講,并沒有共享變量,
但實(shí)際上在cache line 上他們是共享訪問的,這個(gè)就是典型的偽共享。
4.****偽共享與共享 在 cache line 的層面上必須都是共享的。多個(gè)CPU對(duì)共享內(nèi)存的訪問安全通過緩存一致性來保證。
*5*.偽共享問題很難被發(fā)現(xiàn),因?yàn)榫€程可能訪問完全不同的全局變量,內(nèi)存中卻碰巧在很相近的位置上。如其他諸多的并發(fā)問題,避免偽共享的最基本方式是仔細(xì)審查代碼,根據(jù)緩存行來調(diào)整你的數(shù)據(jù)結(jié)構(gòu)。
-
Java 8新增了哪些特性?
答:最核心的特性Lambda 表達(dá)式和函數(shù)式接口以及Stream API
-
Java 8中的Lambda表達(dá)式有什么作用?
答:Lambda 是一個(gè)匿名函數(shù),可以把Lambda表達(dá)式理解為一段可以傳遞的代碼(將代碼像數(shù)據(jù)一樣傳遞)??梢詫懗龈雍啙崱㈧`活的代碼。作為一種更加緊湊的代碼風(fēng)格,使java的語言表達(dá)能力得到了提升。
-
Java 8中的Optional類有什么作用?
答:以解決程序中常見的NullPointerException
異常問題
-
Java 8中的@Repeatable注解有什么作用?
答:@Repeatable可以用來指示某種類型的注解是可以重復(fù)添加的
-
Java 8中的方法引用是指什么?
答:方法引用,如果函數(shù)式接口以及有具體實(shí)現(xiàn)了可以直接引用該方法。語法為ClassName::MethodName || ObjectName::實(shí)例方法名稱
-
Java 8中的Stream有什么作用?
答:提供了對(duì)集合計(jì)算的支持,集合負(fù)責(zé)存儲(chǔ)而Stream負(fù)責(zé)計(jì)算。它用于操作數(shù)據(jù)源所產(chǎn)生的序列,例如復(fù)雜的查找、過濾映射數(shù)據(jù)等操作
-
Java 8中的函數(shù)式編程怎么用?
答:函數(shù)與其他數(shù)據(jù)類型一樣,可以賦值給其他變量,也可以作為參數(shù),也可以作為返回值。
- 代碼簡潔,開發(fā)快速
- 易于理解,降低風(fēng)險(xiǎn)
- 易于并行
- 延遲執(zhí)行
-
如何獲取一個(gè)Stream流對(duì)象?
答:
- 數(shù)組獲取Stream:Arrays.stream(數(shù)組對(duì)象)
- 集合獲取Stream:集合對(duì)象.stream()
- 值獲取Stream:Stream.of(值...)
-
什么是序列化,怎么序列化,為什么序列化,反序列化會(huì)遇到什么問題,如何解決。
答:序列化是將內(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ì)遇到反序列化后的類版本不一致問題,需要保證序列化和反序列化的版本一直