五、面試總結(jié)(五)

對象

拷貝(clone)

如何實現(xiàn)對象克隆

深拷貝和淺拷貝區(qū)別

深拷貝和淺拷貝如何實現(xiàn)激活機制

寫clone()方法時,通常都有一行代碼,是什么

比較

在比較對象時,”==” 運算符和 equals 運算有何區(qū)別

如果要重寫一個對象的equals方法,還要考慮什么

兩個對象值相同(x.equals(y) == true),但卻可有不同的hash code,這句話對不對

構(gòu)造器

構(gòu)造器鏈是什么

創(chuàng)建對象時構(gòu)造器的調(diào)用順序

不可變對象

什么是不可變象(immutable object)

為什么 Java 中的 String 是不可變的(Immutable)

如何構(gòu)建不可變的類結(jié)構(gòu)?關(guān)鍵點在哪里

能創(chuàng)建一個包含可變對象的不可變對象嗎

如何對一組對象進行排序

方法

構(gòu)造器(constructor)是否可被重寫(override)

方法可以同時即是 static 又是 synchronized 的嗎

abstract 的 method是否可同時是 static,是否可同時是 native,是否可同時是synchronized 答案:都不可以,因為abstract申明的方法是要求子類去實現(xiàn)的,abstract只是告訴你有這樣一個接口,你要去實現(xiàn),至于你的具體實現(xiàn)可以是native和synchronized,也可以不是,抽象方法是不關(guān)心這些事的,所以寫這兩個是沒有意義的。然后,static方法是不會被覆蓋的,而abstract方法正是要子類去覆蓋它,所以也是沒有意義的。所以,總的來說,就是java語法不允許你這樣做,事實上,也沒有意義這樣做。
abstract需要重載,static為類方法,沒有重載一說 abstract為沒有實現(xiàn)的方法,native為本機實現(xiàn)的方法,自相矛盾 abstract方法沒有實現(xiàn),也不可能實際調(diào)用抽象方法,沒有必要synchronized修飾,當(dāng)然子類可以根據(jù)需要同步該方法.所以 都不能。

Java支持哪種參數(shù)傳遞類型 答案:Java 應(yīng)用程序有且僅有的一種參數(shù)傳遞機制,即按值傳遞。
對象是按引用傳遞的;
Java 應(yīng)用程序有且僅有的一種參數(shù)傳遞機制,即按值傳遞;
按值傳遞意味著當(dāng)將一個參數(shù)傳遞給一個函數(shù)時,函數(shù)接收的是原始值的一個副本;
按引用傳遞意味著當(dāng)將一個參數(shù)傳遞給一個函數(shù)時,函數(shù)接收的是原始值的內(nèi)存地址,而不是值的副本。

一個對象被當(dāng)作參數(shù)傳遞到一個方法,是值傳遞還是引用傳遞 答案:是值傳遞。Java編程語言中只有由值傳遞參數(shù)的。當(dāng)一個對象實例作為一個參數(shù)被傳遞到方法中時,參數(shù)的值就是該對象的引用。對象的內(nèi)容可以在被調(diào)用的方法中改變,但對象的引用是永遠不會改變的。

當(dāng)一個對象被當(dāng)作參數(shù)傳遞到一個方法后,此方法可改變這個對象的屬性,并可返回變化后的結(jié)果,那么這里到底是值傳遞還是引用傳遞

我們能否重載main()方法

如果main方法被聲明為private會怎樣

GC

概念

GC是什么?為什么要有GC

什么時候會導(dǎo)致垃圾回收

GC是怎么樣運行的

新老以及永久區(qū)是什么

GC 有幾種方式?怎么配置

什么時候一個對象會被GC? 如何判斷一個對象是否存活 答案:參考文章對象是否存活

System.gc() Runtime.gc()會做什么事情? 能保證 GC 執(zhí)行嗎

垃圾回收器可以馬上回收內(nèi)存嗎?有什么辦法主動通知虛擬機進行垃圾回收? 答案:可以。程序員可以手動執(zhí)行System.gc(),通知GC運行,但是Java語言規(guī)范并不保證GC一定會執(zhí)行。

Minor GC 、Major GC、Young GC 與 Full GC分別在什么時候發(fā)生 答案:Minor GC
從年輕代空間(包括 Eden 和 Survivor 區(qū)域)回收內(nèi)存被稱為 Minor GC。
當(dāng) JVM 無法為一個新的對象分配空間時會觸發(fā) Minor GC,比如當(dāng) Eden 區(qū)滿了。所以分配率越高,越頻繁執(zhí)行 Minor GC。
內(nèi)存池被填滿的時候,其中的內(nèi)容全部會被復(fù)制,指針會從0開始跟蹤空閑內(nèi)存。Eden 和 Survivor 區(qū)進行了標(biāo)記和復(fù)制操作,
取代了經(jīng)典的標(biāo)記、掃描、壓縮、清理操作。所以 Eden 和 Survivor 區(qū)不存在內(nèi)存碎片。寫指針總是停留在所使用內(nèi)存池的頂部。
執(zhí)行 Minor GC 操作時,不會影響到永久代。從永久代到年輕代的引用被當(dāng)成 GC roots,從年輕代到永久代的引用在標(biāo)記階段被直接忽略掉。
質(zhì)疑常規(guī)的認知,所有的 Minor GC 都會觸發(fā)“全世界的暫停(stop-the-world)”,停止應(yīng)用程序的線程。對于大部分應(yīng)用程序,停頓導(dǎo)致的延遲都是可以忽略不計的。
其中的真相就 是,大部分 Eden 區(qū)中的對象都能被認為是垃圾,永遠也不會被復(fù)制到 Survivor 區(qū)或者老年代空間。如果正好相反,Eden 區(qū)大部分新生對象不符合 GC 條件,Minor GC 執(zhí)行時暫停的時間將會長很多。
Major GC 是清理永久代。
Full GC 是清理整個堆空間—包括年輕代和永久代。

垃圾回收算法的實現(xiàn)原理

如果對象的引用被置為null,垃圾收集器是否會立即釋放對象占用的內(nèi)存? 答案:垃圾收集器不會立即釋放對象占用的內(nèi)存,在下一個垃圾回收周期中,這個對象將是可被回收的。

垃圾回收的最佳做法是什么 答案:1、標(biāo)記-清除算法:
首先標(biāo)記出所有需要回收的對象,在標(biāo)記完成后統(tǒng)一回收掉所有被標(biāo)記的對象。標(biāo)記過程中 實際上即時上面說的finaLize()的過程。主要缺點一個是效率問題。另外一個是空間問題,標(biāo)記清除后會產(chǎn)生大量不連續(xù)的內(nèi)存碎片。
2、復(fù)制算法:
這種算法將可用內(nèi)存按容量劃分為大小相等的兩塊,每次只使用其中的一塊,當(dāng)這一塊的內(nèi)存用完了。就將還存活著的對象復(fù)制到另外一塊上面,然后再把已經(jīng)使用過的內(nèi)存空間一次清理掉。
3、標(biāo)記-整理算法:
復(fù)制收集算法在對象存活率較高時就要執(zhí)行較多的復(fù)制操作,效率將會遍低。更關(guān)鍵的是,如果不想浪費50%的空間,就需要有額外的空間進行分配擔(dān)保,以對應(yīng)被使用的內(nèi)存中所有對象都100%存活的極端情況,所以在老年代一般不能直接選用這種算法。
標(biāo)記過程仍然與標(biāo)記-清除算法一樣,但是后續(xù)步驟不是直接將對可回收對象進行清理,而是讓所有存活的對象都向領(lǐng)一端移動,然后直接清理掉端邊界以外的內(nèi)存。
4、分代收集算法:
當(dāng)代商業(yè)虛擬機的垃圾收集都采用的是“分代收集算法” ,根據(jù)對象的存活周期的不同,將內(nèi)存化為幾塊,一般是把java堆分為新生代和老年代。這樣就可以根據(jù)各個年代的特點采用最合適的收集算法。
新生代選用復(fù)制算法,老年代使用標(biāo)記-清理算法 或者 標(biāo)記-整理算法。

GC收集器有哪些

垃圾回收器的基本原理是什么?

串行(serial)收集器和吞吐量(throughput)收集器的區(qū)別是什么

Serial 與 Parallel GC之間的不同之處

CMS 收集器 與 G1 收集器的特點與區(qū)別

CMS垃圾回收器的工作過程

JVM 中一次完整的 GC 流程是怎樣的? 對象如何晉升到老年代

吞吐量優(yōu)先和響應(yīng)優(yōu)先的垃圾收集器選擇

GC策略

舉個實際的場景,選擇一個GC策略

JVM的永久代中會發(fā)生垃圾回收嗎

收集方法

標(biāo)記清除、標(biāo)記整理、復(fù)制算法的原理與特點?分別用在什么地方

如果讓你優(yōu)化收集方法,有什么思路

JVM

參數(shù)

說說你知道的幾種主要的jvm 參數(shù) 答案:參考幾個文章(JVM重要參數(shù)配置) 點擊打開鏈接 點擊打開鏈接 點擊打開鏈接

-XX:+UseCompressedOops 有什么作用

類加載器(ClassLoader)

Java 類加載器都有哪些 答案:1)Bootstrap ClassLoader
負責(zé)加載JAVA_HOME中jre/lib/rt.jar里所有的class,由C++實現(xiàn),不是ClassLoader子類 2)Extension ClassLoader 負責(zé)加載java平臺中擴展功能的一些jar包,包括JAVA_HOME中jre/lib/*.jar或-Djava.ext.dirs指定目錄下的jar包
3)App ClassLoader
負責(zé)記載classpath中指定的jar包及目錄中class
4)Custom ClassLoader
屬于應(yīng)用程序根據(jù)自身需要自定義的ClassLoader,如tomcat、jboss都會根據(jù)j2ee規(guī)范自行實現(xiàn)ClassLoader
加載過程中會先檢查類是否被已加載,檢查順序是自底向上,從Custom ClassLoader到BootStrap ClassLoader逐層檢查,只要某個classloader已加載就視為已加載此類,保證此類只所有ClassLoader加載一次。而加載的順序是自頂向下,也就是由上層來逐層嘗試加載此類。

JVM如何加載字節(jié)碼文件 答案:JVM主要完成三件事:
1、通過一個類的全限定名(包名與類名)來獲取定義此類的二進制字節(jié)流(Class文件)。而獲取的方式,可以通過jar包、war包、網(wǎng)絡(luò)中獲取、JSP文件生成等方式。
2、將這個字節(jié)流所代表的靜態(tài)存儲結(jié)構(gòu)轉(zhuǎn)化為方法區(qū)的運行時數(shù)據(jù)結(jié)構(gòu)。這里只是轉(zhuǎn)化了數(shù)據(jù)結(jié)構(gòu),并未合并數(shù)據(jù)。(方法區(qū)就是用來存放已被加載的類信息,常量,靜態(tài)變量,編譯后的代碼的運行時內(nèi)存區(qū)域)
3、在內(nèi)存中生成一個代表這個類的java.lang.Class對象,作為方法區(qū)這個類的各種數(shù)據(jù)的訪問入口。這個Class對象并沒有規(guī)定是在Java堆內(nèi)存中,它比較特殊,雖為對象,但存放在方法區(qū)中。

內(nèi)存管理

JVM內(nèi)存分哪幾個區(qū),每個區(qū)的作用是什么

一個對象從創(chuàng)建到銷毀都是怎么在這些部分里存活和轉(zhuǎn)移的

解釋內(nèi)存中的棧(stack)、堆(heap)和方法區(qū)(method area)的用法

JVM中哪個參數(shù)是用來控制線程的棧堆棧小

簡述內(nèi)存分配與回收策略

簡述重排序,內(nèi)存屏障,happen-before,主內(nèi)存,工作內(nèi)存

Java中存在內(nèi)存泄漏問題嗎?請舉例說明

簡述 Java 中軟引用(SoftReferenc)、弱引用(WeakReference)和虛引用

內(nèi)存映射緩存區(qū)是什么

jstack,jstat,jmap,jconsole怎么用

32 位 JVM 和 64 位 JVM 的最大堆內(nèi)存分別是多數(shù)?32 位和 64 位的 JVM,int 類型變量的長度是多數(shù)?

怎樣通過 Java 程序來判斷 JVM 是 32 位 還是 64 位

JVM自身會維護緩存嗎?是不是在堆中進行對象分配,操作系統(tǒng)的堆還是JVM自己管理堆

什么情況下會發(fā)生棧內(nèi)存溢出

雙親委派模型是什么

多線程

基本概念

什么是線程

多線程的優(yōu)點

多線程的幾種實現(xiàn)方式

用 Runnable 還是 Thread

什么是線程安全

Vector, SimpleDateFormat 是線程安全類嗎

什么 Java 原型不是線程安全的

哪些集合類是線程安全的

多線程中的忙循環(huán)是什么

如何創(chuàng)建一個線程

編寫多線程程序有幾種實現(xiàn)方式

什么是線程局部變量

線程和進程有什么區(qū)別?進程間如何通訊,線程間如何通訊

什么是多線程環(huán)境下的偽共享(false sharing)

同步和異步有何異同,在什么情況下分別使用他們?舉例說明

Current

ConcurrentHashMap 和 Hashtable的區(qū)別

ArrayBlockingQueue, CountDownLatch的用法

ConcurrentHashMap的并發(fā)度是什么

CyclicBarrier 和 CountDownLatch有什么不同?各自的內(nèi)部原理和用法是什么

Semaphore的用法

Thread

啟動一個線程是調(diào)用 run() 還是 start() 方法?start() 和 run() 方法有什么區(qū)別

調(diào)用start()方法時會執(zhí)行run()方法,為什么不能直接調(diào)用run()方法

sleep() 方法和對象的 wait() 方法都可以讓線程暫停執(zhí)行,它們有什么區(qū)別

yield方法有什么作用?sleep() 方法和 yield() 方法有什么區(qū)別

Java 中如何停止一個線程

stop() 和 suspend() 方法為何不推薦使用

如何在兩個線程間共享數(shù)據(jù)

如何強制啟動一個線程

如何讓正在運行的線程暫停一段時間

什么是線程組,為什么在Java中不推薦使用

你是如何調(diào)用 wait(方法的)?使用 if 塊還是循環(huán)?為什么

生命周期

有哪些不同的線程生命周期

線程狀態(tài),BLOCKED 和 WAITING 有什么區(qū)別

畫一個線程的生命周期狀態(tài)圖

ThreadLocal 用途是什么,原理是什么,用的時候要注意什么

ThreadPool

線程池是什么?為什么要使用它

如何創(chuàng)建一個Java線程池

ThreadPool用法與優(yōu)勢

提交任務(wù)時,線程池隊列已滿時會發(fā)會生什么

newCache 和 newFixed 有什么區(qū)別?簡述原理。構(gòu)造函數(shù)的各個參數(shù)的含義是什么,比如 coreSize, maxsize 等

線程池的實現(xiàn)策略

線程池的關(guān)閉方式有幾種,各自的區(qū)別是什么

線程池中submit() 和 execute()方法有什么區(qū)別?

線程調(diào)度

Java中用到的線程調(diào)度算法是什么

什么是多線程中的上下文切換

你對線程優(yōu)先級的理解是什么

什么是線程調(diào)度器 (Thread Scheduler) 和時間分片 (Time Slicing)

線程同步

請說出你所知的線程同步的方法

synchronized 的原理是什么

synchronized 和 ReentrantLock 有什么不同

什么場景下可以使用 volatile 替換 synchronized

有T1,T2,T3三個線程,怎么確保它們按順序執(zhí)行?怎樣保證T2在T1執(zhí)行完后執(zhí)行,T3在T2執(zhí)行完后執(zhí)行

同步塊內(nèi)的線程拋出異常會發(fā)生什么

當(dāng)一個線程進入一個對象的 synchronized 方法A 之后,其它線程是否可進入此對象的 synchronized 方法B

使用 synchronized 修飾靜態(tài)方法和非靜態(tài)方法有什么區(qū)別

如何從給定集合那里創(chuàng)建一個 synchronized 的集合

Java Concurrency API 中 的 Lock 接口是什么?對比同步它有什么優(yōu)勢

Lock 與 Synchronized 的區(qū)別?Lock 接口比 synchronized 塊的優(yōu)勢是什么

ReadWriteLock是什么?

鎖機制有什么用

什么是樂觀鎖(Optimistic Locking)?如何實現(xiàn)樂觀鎖?如何避免ABA問題

解釋以下名詞:重排序,自旋鎖,偏向鎖,輕量級鎖,可重入鎖,公平鎖,非公平鎖,樂觀鎖,悲觀鎖 答案查看文章

什么時候應(yīng)該使用可重入鎖

簡述鎖的等級方法鎖、對象鎖、類鎖 答案:
對象鎖(方法鎖),是針對一個對象的,它只在該對象的某個內(nèi)存位置聲明一個標(biāo)識該對象是否擁有鎖,所有它只會鎖住當(dāng)前的對象,一般一個對象鎖是對一個非靜態(tài)成員變量進行synchronized修飾,或者對一個非靜態(tài)成員方法進行synchronized進行修飾,對于對象鎖,不同對象訪問同一個被synchronized修飾的方法的時候不會阻塞
java的內(nèi)置鎖:每個java對象都可以用做一個實現(xiàn)同步的鎖,這些鎖成為內(nèi)置鎖。線程進入同步代碼塊或方法的時候會自動獲得該鎖,在退出同步代碼塊或方法時會釋放該鎖。獲得內(nèi)置鎖的唯一途徑就是進入這個鎖的保護的同步代碼塊或方法。
java內(nèi)置鎖是一個互斥鎖,這就是意味著最多只有一個線程能夠獲得該鎖,當(dāng)線程A嘗試去獲得線程B持有的內(nèi)置鎖時,線程A必須等待或者阻塞,知道線程B釋放這個鎖,如果B線程不釋放這個鎖,那么A線程將永遠等待下去。
java的對象鎖和類鎖:java的對象鎖和類鎖在鎖的概念上基本上和內(nèi)置鎖是一致的,但是,兩個鎖實際是有很大的區(qū)別的,對象鎖是用于對象實例方法,或者一個對象實例上的,類鎖是用于類的靜態(tài)方法或者一個類的class對象上的。我們知道,類的對象實例可以有很多個,但是每個類只有一個class對象,所以不同對象實例的對象鎖是互不干擾的,但是每個類只有一個類鎖。但是有一點必須注意的是,其實類鎖只是一個概念上的東西,并不是真實存在的,它只是用來幫助我們理解鎖定實例方法和靜態(tài)方法的區(qū)別的
上面已經(jīng)對鎖的一些概念有了一點了解,下面探討synchronized關(guān)鍵字的用法。
synchronized的用法:synchronized修飾方法和synchronized修飾代碼塊。
其實,類鎖修飾方法和代碼塊的效果和對象鎖是一樣的,因為類鎖只是一個抽象出來的概念,只是為了區(qū)別靜態(tài)方法的特點,因為靜態(tài)方法是所有對象實例共用的,所以對應(yīng)著synchronized修飾的靜態(tài)方法的鎖也是唯一的,所以抽象出來個類鎖。其實這里的重點在下面這塊代碼,synchronized同時修飾靜態(tài)和非靜態(tài)方法
synchronized的缺陷:當(dāng)某個線程進入同步方法獲得對象鎖,那么其他線程訪問這里對象的同步方法時,必須等待或者阻塞,這對高并發(fā)的系統(tǒng)是致命的,這很容易導(dǎo)致系統(tǒng)的崩潰。如果某個線程在同步方法里面發(fā)生了死循環(huán),那么它就永遠不會釋放這個對象鎖,那么其他線程就要永遠的等待。這是一個致命的問題。
一個類的對象鎖和另一個類的對象鎖是沒有關(guān)聯(lián)的,當(dāng)一個線程獲得A類的對象鎖時,它同時也可以獲得B類的對象鎖。

Java中活鎖和死鎖有什么區(qū)別?

什么是死鎖(Deadlock)?導(dǎo)致線程死鎖的原因?如何確保 N 個線程可以訪問 N 個資源同時又不導(dǎo)致死鎖

死鎖與活鎖的區(qū)別,死鎖與饑餓的區(qū)別 答案:死鎖:是指兩個或兩個以上的進程(或線程)在執(zhí)行過程中,因爭奪資源而造成的一種互相等待的現(xiàn)象,若無外力作用,它們都將無法推進下去。此時稱系統(tǒng)處于死鎖狀態(tài)或系統(tǒng)產(chǎn)生了死鎖,這些永遠在互相等待的進程稱為死鎖進程。死鎖發(fā)生的四個條件
1、互斥條件:線程對資源的訪問是排他性的,如果一個線程對占用了某資源,那么其他線程必須處于等待狀態(tài),直到資源被釋放。
2、請求和保持條件:線程T1至少已經(jīng)保持了一個資源R1占用,但又提出對另一個資源R2請求,而此時,資源R2被其他線程T2占用,于是該線程T1也必須等待,但又對自己保持的資源R1不釋放。
3、不剝奪條件:線程已獲得的資源,在未使用完之前,不能被其他線程剝奪,只能在使用完以后由自己釋放。
4、環(huán)路等待條件:在死鎖發(fā)生時,必然存在一個“進程-資源環(huán)形鏈”,即:{p0,p1,p2,...pn},進程p0(或線程)等待p1占用的資源,p1等待p2占用的資源,pn等待p0占用的資源。(最直觀的理解是,p0等待p1占用的資源,而p1而在等待p0占用的資源,于是兩個進程就相互等待)
活鎖:是指線程1可以使用資源,但它很禮貌,讓其他線程先使用資源,線程2也可以使用資源,但它很紳士,也讓其他線程先使用資源。這樣你讓我,我讓你,最后兩個線程都無法使用資源。
饑餓:是指如果線程T1占用了資源R,線程T2又請求封鎖R,于是T2等待。T3也請求資源R,當(dāng)T1釋放了R上的封鎖后,系統(tǒng)首先批準了T3的請求,T2仍然等待。然后T4又請求封鎖R,當(dāng)T3釋放了R上的封鎖之后,系統(tǒng)又批準了T4的請求......,T2可能永遠等待。

怎么檢測一個線程是否擁有鎖

如何實現(xiàn)分布式鎖

有哪些無鎖數(shù)據(jù)結(jié)構(gòu),他們實現(xiàn)的原理是什么

讀寫鎖可以用于什么應(yīng)用場景

Executors類是什么? Executor和Executors的區(qū)別 答案:
Executor 和 ExecutorService 這兩個接口主要的區(qū)別是:ExecutorService 接口繼承了 Executor 接口,是 Executor 的子接口
Executor 和 ExecutorService 第二個區(qū)別是:Executor 接口定義了 execute()方法用來接收一個Runnable接口的對象,而 ExecutorService 接口中的 submit()方法可以接受Runnable和Callable接口的對象。
Executor 和 ExecutorService 接口第三個區(qū)別是 Executor 中的 execute() 方法不返回任何結(jié)果,而 ExecutorService 中的 submit()方法可以通過一個 Future 對象返回運算結(jié)果。
Executor 和 ExecutorService 接口第四個區(qū)別是除了允許客戶端提交一個任務(wù),ExecutorService 還提供用來控制線程池的方法。比如:調(diào)用 shutDown() 方法終止線程池??梢酝ㄟ^ 《Java Concurrency in Practice》 一書了解更多關(guān)于關(guān)閉線程池和如何處理 pending 的任務(wù)的知識。
Executors 類提供工廠方法用來創(chuàng)建不同類型的線程池。比如: newSingleThreadExecutor() 創(chuàng)建一個只有一個線程的線程池,newFixedThreadPool(int numOfThreads)來創(chuàng)建固定線程數(shù)的線程池,newCachedThreadPool()可以根據(jù)需要創(chuàng)建新的線程,但如果已有線程是空閑的會重用已有線程。

什么是Java線程轉(zhuǎn)儲(Thread Dump),如何得到它 答案:線程轉(zhuǎn)儲是一個JVM活動線程的列表,它對于分析系統(tǒng)瓶頸和死鎖非常有用。有很多方法可以獲取線程轉(zhuǎn)儲——使用Profiler,Kill-3命令,jstack工具等等。有的更喜歡jstack工具,因為它容易使用并且是JDK自帶的。由于它是一個基于終端的工具,所以可以編寫一些腳本去定時的產(chǎn)生線程轉(zhuǎn)儲以待分析。

如何在Java中獲取線程堆棧

說出 3 條在 Java 中使用線程的最佳實踐

在線程中你怎么處理不可捕捉異常 答案:為了保證主線程不被阻塞,線程之間基本相互隔離,所以線程之間不論是異常還是通信都不共享。當(dāng)然,因為你抓異常是主線程,而異常是在子線程出現(xiàn),可以用thread.setUncaughtExceptionHandler()去處理線程的異常。在Thread中,Java提供了一個setUncaughtExceptionHandler的方法來設(shè)置線程的異常處理函數(shù),你可以把異常處理函數(shù)傳進去,當(dāng)發(fā)生線程的未捕獲異常的時候,由JVM來回調(diào)執(zhí)行。類似的功能就可以組成線程池自己的異常處理機制,正常來說,你想在主線程異步執(zhí)行子線程的代碼并得知是否執(zhí)行成功,可以直接使用Promise模式,即Java中線程池返回的Future對象。

實際項目中使用多線程舉例。你在多線程環(huán)境中遇到的常見的問題是什么?你是怎么解決它的

請說出與線程同步以及線程調(diào)度相關(guān)的方法

程序中有3個 socket,需要多少個線程來處理

假如有一個第三方接口,有很多個線程去調(diào)用獲取數(shù)據(jù),現(xiàn)在規(guī)定每秒鐘最多有 10 個線程同時調(diào)用它,如何做到

如何在 Windows 和 Linux 上查找哪個線程使用的 CPU 時間最長

如何確保 main() 方法所在的線程是 Java 程序最后結(jié)束的線程

非常多個線程(可能是不同機器),相互之間需要等待協(xié)調(diào)才能完成某種工作,問怎么設(shè)計這種協(xié)調(diào)方案

你需要實現(xiàn)一個高效的緩存,它允許多個用戶讀,但只允許一個用戶寫,以此來保持它的完整性,你會怎樣去實現(xiàn)它

異常

基本概念

Error 和 Exception有什么區(qū)別

UnsupportedOperationException是什么

NullPointerException 和 ArrayIndexOutOfBoundException 之間有什么相同之處

什么是受檢查的異常,什么是運行時異常 答案:
Java提供了兩類主要的異常 :runtime exception和checked exception。 checked異常也就是我們經(jīng)常遇到的IO異常,以及SQL異常都是這種異常。 對于這種異常, JAVA編譯器強制要求我們必需對出現(xiàn)的這些異常進行catch 。所以,面對這種異常不管我們是否愿意,只能自己去寫一大堆catch塊去處理可能的異常。 這類異常一般是外部錯誤,例如試圖從文件尾后讀取數(shù)據(jù)等,這并不是程序本身的錯誤,而是在應(yīng)用環(huán)境中出現(xiàn)的外部錯誤. 但是另外一種異常: runtime exception ,也稱運行時異常,我們可以不處理。當(dāng)出現(xiàn)這樣的異常時,總是由虛擬機接管。比如:我們從來沒有人去處理過 NullPointerException 異常,它就是運行時異常,并且這種異常還是最常見的異常之一。

運行時異常與一般異常有何異同

簡述一個你最常見到的runtime exception(運行時異常)

finally

finally關(guān)鍵詞在異常處理中如何使用

如果執(zhí)行finally代碼塊之前方法返回了結(jié)果,或者JVM退出了,finally塊中的代碼還會執(zhí)行嗎

try里有return,finally還執(zhí)行么?那么緊跟在這個try后的finally {}里的code會不會被執(zhí)行,什么時候被執(zhí)行,在return前還是后

在什么情況下,finally語句不會執(zhí)行

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

OOM你遇到過哪些情況?你是怎么搞定的?

SOF你遇到過哪些情況?

既然我們可以用RuntimeException來處理錯誤,那么你認為為什么Java中還存在檢查型異常

當(dāng)自己創(chuàng)建異常類的時候應(yīng)該注意什么

導(dǎo)致空指針異常的原因

異常處理 handle or declare 原則應(yīng)該如何理解

怎么利用 JUnit 來測試一個方法的異常

catch塊里別不寫代碼有什么問題

你曾經(jīng)自定義實現(xiàn)過異常嗎?怎么寫的

什么是 異常鏈

在try塊中可以拋出異常嗎

JDBC

通過 JDBC 連接數(shù)據(jù)庫有哪幾種方式

闡述 JDBC 操作數(shù)據(jù)庫的基本步驟

JDBC 中如何進行事務(wù)處理

什么是 JdbcTemplate

什么是 DAO 模塊

使用 JDBC 操作數(shù)據(jù)庫時,如何提升讀取數(shù)據(jù)的性能?如何提升更新數(shù)據(jù)的性能

列出 5 個應(yīng)該遵循的 JDBC 最佳實踐

IO

File

File類型中定義了什么方法來創(chuàng)建一級目錄

File類型中定義了什么方法來判斷一個文件是否存在

為了提高讀寫性能,可以采用什么流

Java中有幾種類型的流

JDK 為每種類型的流提供了一些抽象類以供繼承,分別是哪些類

對文本文件操作用什么I/O流

對各種基本數(shù)據(jù)類型和String類型的讀寫,采用什么流

能指定字符編碼的 I/O 流類型是什么

序列化

什么是序列化?如何實現(xiàn) Java 序列化及注意事項

Serializable 與 Externalizable 的區(qū)別

Socket

socket 選項 TCP NO DELAY 是指什么

Socket 工作在 TCP/IP 協(xié)議棧是哪一層

TCP、UDP 區(qū)別及 Java 實現(xiàn)方式

說幾點 IO 的最佳實踐

直接緩沖區(qū)與非直接緩沖器有什么區(qū)別?

怎么讀寫 ByteBuffer?ByteBuffer 中的字節(jié)序是什么

當(dāng)用System.in.read(buffer)從鍵盤輸入一行n個字符后,存儲在緩沖區(qū)buffer中的字節(jié)數(shù)是多少

如何使用掃描器類(Scanner Class)令牌化

面向?qū)ο缶幊蹋∣OP)

解釋下多態(tài)性(polymorphism),封裝性(encapsulation),內(nèi)聚(cohesion)以及耦合(coupling)

多態(tài)的實現(xiàn)原理

封裝、繼承和多態(tài)是什么

對象封裝的原則是什么?

獲得一個類的類對象有哪些方式

重載(Overload)和重寫(Override)的區(qū)別。重載的方法能否根據(jù)返回類型進行區(qū)分?

說出幾條 Java 中方法重載的最佳實踐

抽象類

抽象類和接口的區(qū)別

抽象類中是否可以有靜態(tài)的main方法

抽象類是否可實現(xiàn)(implements)接口

抽象類是否可繼承具體類(concrete class)

匿名類(Anonymous Inner Class)

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

內(nèi)部類

內(nèi)部類分為幾種

內(nèi)部類可以引用它的包含類(外部類)的成員嗎

請說一下 Java 中為什么要引入內(nèi)部類?還有匿名內(nèi)部類

繼承

繼承(Inheritance)與聚合(Aggregation)的區(qū)別在哪里

繼承和組合之間有什么不同

為什么類只能單繼承,接口可以多繼承

存在兩個類,B 繼承 A,C 繼承 B,能將 B 轉(zhuǎn)換為 C 么?如 C = (C) B

如果類 a 繼承類 b,實現(xiàn)接口c,而類 b 和接口 c 中定義了同名變量,請問會出現(xiàn)什么問題

接口

接口是什么

接口是否可繼承接口

為什么要使用接口而不是直接使用具體類?接口有什么優(yōu)點

泛型

泛型的存在是用來解決什么問題

泛型的常用特點

List能否轉(zhuǎn)為List

工具類

日歷

Calendar Class的用途

如何在Java中獲取日歷類的實例

解釋一些日歷類中的重要方法

GregorianCalendar 類是什么

SimpleTimeZone 類是什么

Locale類是什么

如何格式化日期對象

如何添加小時(hour)到一個日期對象(Date Objects)

如何將字符串 YYYYMMDD 轉(zhuǎn)換為日期

Math

Math.round()什么作用?Math.round(11.5) 等于多少?Math.round(-11.5)等于多少?

XML

XML文檔定義有幾種形式?它們之間有何本質(zhì)區(qū)別?解析XML文檔有哪幾種方式?DOM 和 SAX 解析器有什么不同?

Java解析XML的方式

用 jdom 解析 xml 文件時如何解決中文問題?如何解析

你在項目中用到了 XML 技術(shù)的哪些方面?如何實現(xiàn)

動態(tài)代理

描述動態(tài)代理的幾種實現(xiàn)方式,分別說出相應(yīng)的優(yōu)缺點

設(shè)計模式

什么是設(shè)計模式(Design Patterns)?你用過哪種設(shè)計模式?用在什么場合

你知道哪些商業(yè)級設(shè)計模式?

哪些設(shè)計模式可以增加系統(tǒng)的可擴展性

單例模式

除了單例模式,你在生產(chǎn)環(huán)境中還用過什么設(shè)計模式?

寫 Singleton 單例模式

單例模式的雙檢鎖是什么

如何創(chuàng)建線程安全的 Singleton

什么是類的單例模式

寫出三種單例模式實現(xiàn)

適配器模式

適配器模式是什么?什么時候使用

適配器模式和代理模式之前有什么不同

適配器模式和裝飾器模式有什么區(qū)別

什么時候使用享元模式

什么時候使用組合模式

什么時候使用訪問者模式

什么是模板方法模式

請給出1個符合開閉原則的設(shè)計模式的例子

開放問題

用一句話概括 Web 編程的特點

Google是如何在一秒內(nèi)把搜索結(jié)果返回給用戶

哪種依賴注入方式你建議使用,構(gòu)造器注入,還是 Setter方法注入

樹(二叉或其他)形成許多普通數(shù)據(jù)結(jié)構(gòu)的基礎(chǔ)。請描述一些這樣的數(shù)據(jù)結(jié)構(gòu)以及何時可以使用它們

某一項功能如何設(shè)計

線上系統(tǒng)突然變得異常緩慢,你如何查找問題

什么樣的項目不適合用框架

新浪微博是如何實現(xiàn)把微博推給訂閱者

簡要介紹下從瀏覽器輸入 URL 開始到獲取到請求界面之后 Java Web 應(yīng)用中發(fā)生了什么

請你談?wù)凷SH整合

高并發(fā)下,如何做到安全的修改同一行數(shù)據(jù)

12306網(wǎng)站的訂票系統(tǒng)如何實現(xiàn),如何保證不會票不被超賣

網(wǎng)站性能優(yōu)化如何優(yōu)化的

聊了下曾經(jīng)參與設(shè)計的服務(wù)器架構(gòu)

請思考一個方案,實現(xiàn)分布式環(huán)境下的 countDownLatch

請思考一個方案,設(shè)計一個可以控制緩存總體大小的自動適應(yīng)的本地緩存

在你的職業(yè)生涯中,算得上最困難的技術(shù)挑戰(zhàn)是什么

如何寫一篇設(shè)計文檔,目錄是什么

大寫的O是什么?舉幾個例子

編程中自己都怎么考慮一些設(shè)計原則的,比如開閉原則,以及在工作中的應(yīng)用

解釋一下網(wǎng)絡(luò)應(yīng)用的模式及其特點

設(shè)計一個在線文檔系統(tǒng),文檔可以被編輯,如何防止多人同時對同一份文檔進行編輯更新

說出數(shù)據(jù)連接池的工作機制是什么

怎么獲取一個文件中單詞出現(xiàn)的最高頻率

描述一下你最常用的編程風(fēng)格

如果有機會重新設(shè)計你們的產(chǎn)品,你會怎么做

如何搭建一個高可用系統(tǒng)

如何啟動時不需輸入用戶名與密碼

如何在基于Java的Web項目中實現(xiàn)文件上傳和下載

如何實現(xiàn)一個秒殺系統(tǒng),保證只有幾位用戶能買到某件商品。

如何實現(xiàn)負載均衡,有哪些算法可以實現(xiàn)

如何設(shè)計一個購物車?想想淘寶的購物車如何實現(xiàn)的

如何設(shè)計一套高并發(fā)支付方案,架構(gòu)如何設(shè)計

如何設(shè)計建立和保持 100w 的長連接

如何避免瀏覽器緩存。

如何防止緩存雪崩

如果AB兩個系統(tǒng)互相依賴,如何解除依

如果有人惡意創(chuàng)建非法連接,怎么解決

如果有幾十億的白名單,每天白天需要高并發(fā)查詢,晚上需要更新一次,如何設(shè)計這個功能

如果系統(tǒng)要使用超大整數(shù)(超過long長度范圍),請你設(shè)計一個數(shù)據(jù)結(jié)構(gòu)來存儲這種超大型數(shù)字以及設(shè)計一種算法來實現(xiàn)超大整數(shù)加法運算)

如果要設(shè)計一個圖形系統(tǒng),請你設(shè)計基本的圖形元件(Point,Line,Rectangle,Triangle)的簡單實現(xiàn)

如果讓你實現(xiàn)一個并發(fā)安全的鏈表,你會怎么做

應(yīng)用服務(wù)器與WEB 服務(wù)器的區(qū)別?應(yīng)用服務(wù)器怎么監(jiān)控性能,各種方式的區(qū)別?你使用過的應(yīng)用服務(wù)器優(yōu)化技術(shù)有哪些

大型網(wǎng)站在架構(gòu)上應(yīng)當(dāng)考慮哪些問題

有沒有處理過線上問題?出現(xiàn)內(nèi)存泄露,CPU利用率標(biāo)高,應(yīng)用無響應(yīng)時如何處理的

最近看什么書,印象最深刻的是什么

描述下常用的重構(gòu)技巧

你使用什么版本管理工具?分支(Branch)與標(biāo)簽(Tag)之間的區(qū)別在哪里

你有了解過存在哪些反模式(Anti-Patterns)嗎

你用過的網(wǎng)站前端優(yōu)化的技術(shù)有哪些

如何分析Thread dump

你如何理解AOP中的連接點(Joinpoint)、切點(Pointcut)、增強(Advice)、引介(Introduction)、織入(Weaving)、切面(Aspect)這些概念

你是如何處理內(nèi)存泄露或者棧溢出問題的

你們線上應(yīng)用的 JVM 參數(shù)有哪些

怎么提升系統(tǒng)的QPS和吞吐量

知識面

解釋什么是 MESI 協(xié)議(緩存一致性)

談?wù)?reactor 模型

Java 9 帶來了怎樣的新功能

Java 與 C++ 對比,C++ 或 Java 中的異常處理機制的簡單原理和應(yīng)用

簡單講講 Tomcat 結(jié)構(gòu),以及其類加載器流程

虛擬內(nèi)存是什么

闡述下 SOLID 原則

請簡要講一下你對測試驅(qū)動開發(fā)(TDD)的認識

CDN實現(xiàn)原理

Maven 和 ANT 有什么區(qū)別

UML中有哪些常用的圖

Linux

Linux 下 IO 模型有幾種,各自的含義是什么。

Linux 系統(tǒng)下你關(guān)注過哪些內(nèi)核參數(shù),說說你知道的

Linux 下用一行命令查看文件的最后五行

平時用到哪些 Linux 命令

用一行命令輸出正在運行的 Java 進程

使用什么命令來確定是否有 Tomcat 實例運行在機器上

什么是 N+1 難題

什么是 paxos 算法

什么是 restful,講講你理解的 restful

什么是 zab 協(xié)議

什么是領(lǐng)域模型(domain model)?貧血模型(anaemic domain model) 和充血模型(rich domain model)有什么區(qū)別

什么是領(lǐng)域驅(qū)動開發(fā)(Domain Driven Development)

介紹一下了解的 Java 領(lǐng)域的 Web Service 框架

Web Server、Web Container 與 Application Server 的區(qū)別是什么

微服務(wù)(MicroServices)與巨石型應(yīng)用(Monolithic Applications)之間的區(qū)別在哪里

描述 Cookie 和 Session 的作用,區(qū)別和各自的應(yīng)用范圍,Session工作原理

你常用的持續(xù)集成(Continuous Integration)、靜態(tài)代碼分析(Static Code Analysis)工具有哪些

簡述下數(shù)據(jù)庫正則化(Normalizations)

KISS,DRY,YAGNI 等原則是什么含義

分布式事務(wù)的原理,優(yōu)缺點,如何使用分布式事務(wù)?

布式集群下如何做到唯一序列號

網(wǎng)絡(luò)

HTTPS 的加密方式是什么,講講整個加密解密流程

HTTPS和HTTP的區(qū)別

HTTP連接池實現(xiàn)原理

HTTP集群方案

Nginx、lighttpd、Apache三大主流 Web服務(wù)器的區(qū)別

是否看過框架的一些代碼

持久層設(shè)計要考慮的問題有哪些?你用過的持久層框架有哪些

數(shù)值提升是什么

你能解釋一下里氏替換原則嗎

你是如何測試一個應(yīng)用的?知道哪些測試框架

傳輸層常見編程協(xié)議有哪些?并說出各自的特點

編程題

計算加班費

加班10小時以下加班費是時薪的1.5倍。加班10小時或以上,按4元/時算。提示:(一個月工作26天,一天正常工作8小時)

計算1000月薪,加班9小時的加班費

計算2500月薪,加班11小時的加班費

計算1000月薪,加班15小時的加班費

賣東西

一家商場有紅蘋果和青蘋果出售。(紅蘋果5元/個,青蘋果4元/個)。

模擬一個進貨。紅蘋果跟青蘋果各進200個。

模擬一個出售。紅蘋果跟青蘋果各買出10個。每賣出一個蘋果需要進行統(tǒng)計。

提示:一個蘋果是一個單獨的實體。

日期提取

有這樣一個時間字符串:2008-8-8 20:08:08 , 請編寫能夠匹配它的正則表達式,并編寫Java代碼將日期后面的時分秒提取出來,即:20:08:08

線程

8設(shè)計4個線程,其中兩個線程每次對j增加1,另外兩個線程對j每次減少1。寫出程序。

用Java寫一個多線程程序,如寫四個線程,二個加1,二個對一個變量減一,輸出

wait-notify 寫一段代碼來解決生產(chǎn)者-消費者問題

數(shù)字

判斷101-200之間有多少個素數(shù),并輸出所有素數(shù)

用最有效率的方法算出2乘以17等于多少

有 1 億個數(shù)字,其中有 2 個是重復(fù)的,快速找到它,時間和空間要最優(yōu)

2 億個隨機生成的無序整數(shù),找出中間大小的值

10 億個數(shù)字里里面找最小的 10 個

1到1億的自然數(shù),求所有數(shù)的拆分后的數(shù)字之和,如286 拆分成2、8、6,如1到11拆分后的數(shù)字之和 => 1 + … + 9 + 1 + 0 + 1 + 1

一個數(shù)如果恰好等于它的因子之和,這個數(shù)就稱為 “完數(shù) “。例如6=1+2+3.編程 找出1000以內(nèi)的所有完數(shù)

一個數(shù)組中所有的元素都出現(xiàn)了三次,只有一個元素出現(xiàn)了一次找到這個元素

一球從100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在 第10次落地時,共經(jīng)過多少米?第10次反彈多高?

求100-1000內(nèi)質(zhì)數(shù)的和

求1到100的和的平均數(shù)

求s=a+a+aaa+aaaa+aa…a的值,其中a是一個數(shù)字。例如2+22+222+2222+22222(此時共有5個數(shù)相加),幾個數(shù)相加有鍵盤控制。 求出1到100的和

算出1到40的質(zhì)數(shù),放進數(shù)組里

顯示放組里的數(shù)

找出第[5]個數(shù)

刪除第[9]個數(shù),再顯示刪除后的第[9]個

有 3n+1 個數(shù)字,其中 3n 個中是重復(fù)的,只有 1 個是不重復(fù)的,怎么找出來。

有一組數(shù)1.1.2.3.5.8.13.21.34。寫出程序隨便輸入一個數(shù)就能給出和前一組數(shù)字同規(guī)律的頭5個數(shù)

計算指定數(shù)字的階乘

開發(fā) Fizz Buzz

給定一個包含 N 個整數(shù)的數(shù)組,找出丟失的整數(shù)

一個排好序的數(shù)組,找出兩數(shù)之和為m的所有組合

將一個正整數(shù)分解質(zhì)因數(shù)。例如:輸入90,打印出90=233*5。

打印出所有的 “水仙花數(shù) “,所謂 “水仙花數(shù) “是指一個三位數(shù),其各位數(shù)字立方和等于該數(shù)本身。例如:153是一個 “水仙花數(shù) “,因為153=1的三次方+5的三次方+3的三次方

原地交換兩個變量的值

找出4字節(jié)整數(shù)的中位數(shù)

找到整數(shù)的平方根

實現(xiàn)斐波那契

網(wǎng)絡(luò)

用Java Socket編程,讀服務(wù)器幾個字符,再寫入本地顯示

反射

反射機制提供了什么功能?

反射是如何實現(xiàn)的

哪里用到反射機制

反射中 Class.forName 和 ClassLoader 區(qū)別

反射創(chuàng)建類實例的三種方式是什么

如何通過反射調(diào)用對象的方法

如何通過反射獲取和設(shè)置對象私有字段的值

反射機制的優(yōu)缺點

數(shù)據(jù)庫

寫一段 JDBC 連Oracle的程序,并實現(xiàn)數(shù)據(jù)查詢

算法

50個人圍坐一圈,當(dāng)數(shù)到三或者三的倍數(shù)出圈,問剩下的人是誰,原來的位置是多少

實現(xiàn)一個電梯模擬器用

寫一個冒泡排序

寫一個折半查找

隨機產(chǎn)生20個不能重復(fù)的字符并排序

寫一個函數(shù),傳入 2 個有序的整數(shù)數(shù)組,返回一個有序的整數(shù)數(shù)組

寫一段代碼在遍歷 ArrayList 時移除一個元素

古典問題:有一對兔子,從出生后第3個月起每個月都生一對兔子,小兔子長到第四個月后每個月又生一對兔子,假如兔子都不死,問每個月的兔子總數(shù)為多少

約瑟芬環(huán)游戲

正則

請編寫一段匹配IP地址的正則表達式

寫出一個正則表達式來判斷一個字符串是否是一個數(shù)字

字符串

寫一個方法,入一個文件名和一個字符串,統(tǒng)計這個字符串在這個文件中出現(xiàn)的次數(shù)。

寫一個程序找出所有字符串的組合,并檢查它們是否是回文串

寫一個字符串反轉(zhuǎn)函數(shù),輸入abcde轉(zhuǎn)換成edcba代碼

小游戲,倒轉(zhuǎn)句子中的單詞

將GB2312編碼的字符串轉(zhuǎn)換為ISO-8859-1編碼的字符串

請寫一段代碼來計算給定文本內(nèi)字符“A”的個數(shù)。分別用迭代和遞歸兩種方式

編寫一個截取字符串的函數(shù),輸入為一個字符串和字節(jié)數(shù),輸出為按字節(jié)截取的字符串。 但是要保證漢字不被截半個,如“我ABC”4,應(yīng)該截為“我AB”,輸入“我ABC漢DEF”,6,應(yīng)該輸出為“我ABC”而不是“我ABC+漢的半個”

給定 2 個包含單詞列表(每行一個)的文件,編程列出交集

打印出一個字符串的所有排列

將一個鍵盤輸入的數(shù)字轉(zhuǎn)化成中文輸出(例如:輸入1234567,輸出:一百二拾三萬四千五百六拾七)

在Web應(yīng)用開發(fā)過程中經(jīng)常遇到輸出某種編碼的字符,如從 GBK 到 ISO8859-1等,如何輸出一個某種編碼的字符串

日期

計算兩個日期之間的差距

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法,類相關(guān)的語法,內(nèi)部類的語法,繼承相關(guān)的語法,異常的語法,線程的語...
    子非魚_t_閱讀 34,625評論 18 399
  • Java8張圖 11、字符串不變性 12、equals()方法、hashCode()方法的區(qū)別 13、...
    Miley_MOJIE閱讀 3,886評論 0 11
  • 01 昨天和閨蜜小葉在微信聊天,她說我必須要向你吐槽一下小陽了,她的另一個從高中就相識的閨蜜。 小葉說,雖然我們是...
    阿歡兔小姐閱讀 842評論 0 1
  • 在微博上開#畢業(yè)后的第一年#的話題快一年了,我也畢業(yè)一年了。 想到昨天一個姐姐說“職場前三年,真的是非常痛苦,你會...
    林瀟Ena閱讀 549評論 0 0
  • 郭芳艷 焦點網(wǎng)絡(luò)初級五期 堅持原創(chuàng)分享第135天 昨天的作業(yè)挪到今天做。劉老師在本次課程中給大家...
    冰山藍鷹閱讀 635評論 0 0

友情鏈接更多精彩內(nèi)容