




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
2023年Java面試題+詳細(xì)總結(jié)ThreadLocal(線程變量副本)Synchronized實(shí)現(xiàn)內(nèi)存共享,ThreadLocal為每個線程維護(hù)一個本地變量。采用空間換時間,它用于線程間的數(shù)據(jù)隔離,為每一個使用該變量的線程提供一個副本,每個線程都可以獨(dú)立地改變自己的副本,而不會和其他線程的副本沖突。ThreadLocal類中維護(hù)一個Map,用于存儲每一個線程的變量副本,Map中元素的鍵為線程對象,而值為對應(yīng)線程的變量副本。ThreadLocal在Spring中發(fā)揮著巨大的作用,在管理Request作用域中的Bean、事務(wù)管理、任務(wù)調(diào)度、AOP等模塊都出現(xiàn)了它的身影。Spring中絕大部分Bean都可以聲明成Singleton作用域,采用ThreadLocal進(jìn)行封裝,因此有狀態(tài)的Bean就能夠以singleton的方式在多線程中正常工作了。“你能不能談?wù)?,javaGC是在什么時候,對什么東西,做了什么事情?”在什么時候:1、新生代有一個Eden區(qū)和兩個survivor區(qū),首先將對象放入Eden區(qū),如果空間不足就向其中的一個survivor區(qū)上放,如果仍然放不下就會引發(fā)一次發(fā)生在新生代的minorGC,將存活的對象放入另一個survivor區(qū)中,然后清空Eden和之前的那個survivor區(qū)的內(nèi)存。在某次GC過程中,如果發(fā)現(xiàn)仍然又放不下的對象,就將這些對象放入老年代內(nèi)存里去。2、大對象以及長期存活的對象直接進(jìn)入老年區(qū)。3、當(dāng)每次執(zhí)行minorGC的時候應(yīng)該對要晉升到老年代的對象進(jìn)行分析,如果這些馬上要到老年區(qū)的老年對象的大小超過了老年區(qū)的剩余大小,那么執(zhí)行一次FullGC以盡可能地獲得老年區(qū)的空間。對什么東西:從GCRoots搜索不到,而且經(jīng)過一次標(biāo)記清理之后仍沒有復(fù)活的對象。做什么:新生代:復(fù)制清理;老年代:標(biāo)記-清除和標(biāo)記-壓縮算法;永久代:存放Java中的類和加載類的類加載器本身。GCRoots都有哪些:1.虛擬機(jī)棧中的引用的對象2.方法區(qū)中靜態(tài)屬性引用的對象,常量引用的對象3.本地方法棧中JNI(即一般說的Native方法)引用的對象。Synchronized與LocSynchronized與Lock都是可重入鎖,同一個線程再次進(jìn)入同步代碼的時候??梢允褂米约阂呀?jīng)獲取到的鎖。Synchronized是悲觀鎖機(jī)制,獨(dú)占鎖。而Locks.ReentrantLock是,每次不加鎖而是假設(shè)沒有沖突而去完成某項(xiàng)操作,如果因?yàn)闆_突失敗就重試,直到成功為止。ReentrantLock適用場景1、某個線程在等待一個鎖的控制權(quán)的這段時間需要中斷;2、需要分開處理一些wait-notify,ReentrantLock里面的Condition應(yīng)用,能夠控制notify哪個線程,鎖可以綁定多個條件;3、具有公平鎖功能,每個到來的線程都將排隊(duì)等候。StringBuffer是線程安全的,每次操作字符串,String會生成一個新的對象,而StringBuffer不會;StringBuilder是非線程安全的。fail-fast是什么?fail-fast:機(jī)制是java集合(Collection)中的一種錯誤機(jī)制。當(dāng)多個線程對同一個集合的內(nèi)容進(jìn)行操作時,就可能會產(chǎn)生fail-fast事件。例如:當(dāng)某一個線程A通過iterator去遍歷某集合的過程中,若該集合的內(nèi)容被其他線程所改變了;那么線程A訪問集合時,就會拋出ConcurrentModificationException異常,產(chǎn)生fail-fast事件。happens-beforehappens-before:如果兩個操作之間具有happens-before關(guān)系,那么前一個操作的結(jié)果就會對后面一個操作可見。1、程序順序規(guī)則:一個線程中的每個操作,happens-before于該線程中的任意后續(xù)操作。2、監(jiān)視器鎖規(guī)則:對一個監(jiān)視器鎖的解鎖,happens-before于隨后對這個監(jiān)視器鎖的加鎖。3、volatile變量規(guī)則:對一個volatile域的寫,happens-before于任意后續(xù)對這個volatile域的讀。4、傳遞性:如果Ahappens-beforeB,且Bhappens-beforeC,那么Ahappens-beforeC。5、線程啟動規(guī)則:Thread對象的start()方法happens-before于此線程的每一個動作。Volatile和Synchronized的不同點(diǎn)Volatile和Synchronized四個不同點(diǎn):1、粒度不同,前者針對變量,后者鎖對象和類;2、syn阻塞,volatile線程不阻塞;3、syn保證三大特性,volatile不保證原子性;4、syn編譯器優(yōu)化,volatile不優(yōu)化volatile具備兩種特性:a. 保證此變量對所有線程的可見性,指一條線程修改了這個變量的值,新值對于其他線程來說是可見的,但并不是多線程安全的;b. 禁止指令重排序優(yōu)化。Volatile如何保證內(nèi)存可見性:1、當(dāng)寫一個volatile變量時,JMM會把該線程對應(yīng)的本地內(nèi)存中的共享變量刷新到主內(nèi)存。2、當(dāng)讀一個volatile變量時,JMM會把該線程對應(yīng)的本地內(nèi)存置為無效。線程接下來將從主內(nèi)存中讀取共享變量。同步:就是一個任務(wù)的完成需要依賴另外一個任務(wù),只有等待被依賴的任務(wù)完成后,依賴任務(wù)才能完成。異步:不需要等待被依賴的任務(wù)完成,只是通知被依賴的任務(wù)要完成什么工作,只要自己任務(wù)完成了就算完成了,被依賴的任務(wù)是否完成會通知回來。(異步的特點(diǎn)就是通知)。打電話和發(fā)短信來比喻同步和異步操作。阻塞:CPU停下來等一個慢的操作完成以后,才會接著完成其他的工作。非阻塞:非阻塞就是在這個慢的執(zhí)行時,CPU去做其他工作,等這個慢的完成后,CPU才會接著完成后續(xù)的操作。非阻塞會造成線程切換增加,增加CPU的使用時間能不能補(bǔ)償系統(tǒng)的切換成本需要考慮。CASCAS(CompareAndSwap)無鎖算法:CAS是樂觀鎖技術(shù),當(dāng)多個線程嘗試使用CAS同時更新同一個變量時,只有其中一個線程能更新變量的值,而其它線程都失敗,失敗的線程并不會被掛起,而是被告知這次競爭中失敗,并可以再次嘗試。CAS有3個操作數(shù),內(nèi)存值V,舊的預(yù)期值A(chǔ),要修改的新值B。當(dāng)且僅當(dāng)預(yù)期值A(chǔ)和內(nèi)存值V相同時,將內(nèi)存值V修改為B,否則什么都不做。線程池的作用線程池的作用:在程序啟動的時候就創(chuàng)建若干線程來響應(yīng)處理,它們被稱為線程池,里面的線程叫工作線程。第一:降低資源消耗。通過重復(fù)利用已創(chuàng)建的線程降低線程創(chuàng)建和銷毀造成的消耗。第二:提高響應(yīng)速度。當(dāng)任務(wù)到達(dá)時,任務(wù)可以不需要等到線程創(chuàng)建就能立即執(zhí)行。第三:提高線程的可管理性。常用線程池:ExecutorService是主要的實(shí)現(xiàn)類,其中常用的有Executors.newSingleThreadPool()、newFixedThreadPool()、newcachedTheadPool()、newScheduledThreadPool()。類加載器工作機(jī)制裝載:將Java二進(jìn)制代碼導(dǎo)入jvm中,生成Class文件。連接:a)校驗(yàn):檢查載入Class文件數(shù)據(jù)的正確性;b)準(zhǔn)備:給類的靜態(tài)變量分配存儲空間;c)解析:將符號引用轉(zhuǎn)成直接引用。初始化:對類的靜態(tài)變量,靜態(tài)方法和靜態(tài)代碼塊執(zhí)行初始化工作。雙親委派模型:類加載器收到類加載請求,首先將請求委派給父類加載器完成,用戶自定義加載器->應(yīng)用程序加載器->擴(kuò)展類加載器->啟動類加載器。Redis數(shù)據(jù)結(jié)構(gòu)String—字符串(key-value類型)Hash—字典(hashmap)Redis的哈希結(jié)構(gòu)可以使你像在數(shù)據(jù)庫中更新一個屬性一樣只修改某一項(xiàng)屬性值List—列表實(shí)現(xiàn)消息隊(duì)列Set—集合利用唯一性SortedSet—有序集合可以進(jìn)行排序可以實(shí)現(xiàn)數(shù)據(jù)持久化索引:B+,B-,全文索引Mysql的索引是一個數(shù)據(jù)結(jié)構(gòu),旨在使數(shù)據(jù)庫高效的查找數(shù)據(jù)。常用的數(shù)據(jù)結(jié)構(gòu)是B+Tree,每個葉子節(jié)點(diǎn)不但存放了索引鍵的相關(guān)信息還增加了指向相鄰葉子節(jié)點(diǎn)的指針,這樣就形成了帶有順序訪問指針的B+Tree,做這個優(yōu)化的目的是提高不同區(qū)間訪問的性能。什么時候使用索引:1、經(jīng)常出現(xiàn)在groupby,orderby和distinc關(guān)鍵字后面的字段。2、經(jīng)常與其他表進(jìn)行連接的表,在連接字段上應(yīng)該建立索引。3、經(jīng)常出現(xiàn)在Where子句中的字段。4、經(jīng)常出現(xiàn)用作查詢選擇的字段。SpringIOCSpring支持三種依賴注入方式,分別是屬性(Setter方法)注入,構(gòu)造注入和接口注入。在Spring中,那些組成應(yīng)用的主體及由SpringIOC容器所管理的對象被稱之為Bean。Spring的IOC容器通過反射的機(jī)制實(shí)例化Bean并建立Bean之間的依賴關(guān)系。簡單地講,Bean就是由SpringIOC容器初始化、裝配及被管理的對象。獲取Bean對象的過程,首先通過Resource加載配置文件并啟動IOC容器,然后通過getBean方法獲取bean對象,就可以調(diào)用他的方法。SpringBean的作用域:Singleton:SpringIOC容器中只有一個共享的Bean實(shí)例,一般都是Singleton作用域。Prototype:每一個請求,會產(chǎn)生一個新的Bean實(shí)例。Request:每一次http請求會產(chǎn)生一個新的Bean實(shí)例。代理都有哪些?代理的共有優(yōu)點(diǎn):業(yè)務(wù)類只需要關(guān)注業(yè)務(wù)邏輯本身,保證了業(yè)務(wù)類的重用性。Java靜態(tài)代理:代理對象和目標(biāo)對象實(shí)現(xiàn)了相同的接口,目標(biāo)對象作為代理對象的一個屬性,具體接口實(shí)現(xiàn)中,代理對象可以在調(diào)用目標(biāo)對象相應(yīng)方法前后加上其他業(yè)務(wù)處理邏輯。缺點(diǎn):一個代理類只能代理一個業(yè)務(wù)類。如果業(yè)務(wù)類增加方法時,相應(yīng)的代理類也要增加方法。Java動態(tài)代理:Java動態(tài)代理是寫一個類實(shí)現(xiàn)InvocationHandler接口,重寫Invoke方法,在Invoke方法可以進(jìn)行增強(qiáng)處理的邏輯的編寫,這個公共代理類在運(yùn)行的時候才能明確自己要代理的對象,同時可以實(shí)現(xiàn)該被代理類的方法的實(shí)現(xiàn),然后在實(shí)現(xiàn)類方法的時候可以進(jìn)行增強(qiáng)處理。實(shí)際上:代理對象的方法=增強(qiáng)處理+被代理對象的方法JDK和CGLIB生成動態(tài)代理類的區(qū)別:JDK動態(tài)代理只能針對實(shí)現(xiàn)了接口的類生成代理(實(shí)例化一個類)。此時代理對象和目標(biāo)對象實(shí)現(xiàn)了相同的接口,目標(biāo)對象作為代理對象的一個屬性,具體接口實(shí)現(xiàn)中,可以在調(diào)用目標(biāo)對象相應(yīng)方法前后加上其他業(yè)務(wù)處理邏輯。CGLIB是針對類實(shí)現(xiàn)代理,主要是對指定的類生成一個子類(沒有實(shí)例化一個類),覆蓋其中的方法。SpringMVC運(yùn)行原理1、客戶端請求提交到DispatcherServlet。2、由DispatcherServlet控制器查詢HandlerMapping,找到并分發(fā)到指定的Controller中。3、Controller調(diào)用業(yè)務(wù)邏輯處理后,返回ModelAndView。4、DispatcherServlet查詢一個或多個ViewResoler視圖解析器,找到ModelAndView指定的視圖。5、視圖負(fù)責(zé)將結(jié)果顯示到客戶端。一個Http請求DNS域名解析–>發(fā)起TCP的三次握手–>建立TCP連接后發(fā)起http請求–>服務(wù)器響應(yīng)http請求,瀏覽器得到html代碼–>瀏覽器解析html代碼,并請求html代碼中的資源(如javascript、css、圖片等)–>瀏覽器對頁面進(jìn)行渲染呈現(xiàn)給用戶。設(shè)計(jì)存儲海量數(shù)據(jù)的存儲系統(tǒng):設(shè)計(jì)一個叫“中間層”的一個邏輯層,在這個層,將數(shù)據(jù)庫的海量數(shù)據(jù)抓出來,做成緩存,運(yùn)行在服務(wù)器的內(nèi)存中,同理,當(dāng)有新的數(shù)據(jù)到來,也先做成緩存,再想辦法,持久化到數(shù)據(jù)庫中,這是一個簡單的思路。主要的步驟是負(fù)載均衡,將不同用戶的請求分發(fā)到不同的處理節(jié)點(diǎn)上,然后先存入緩存,定時向主數(shù)據(jù)庫更新數(shù)據(jù)。讀寫的過程采用類似樂觀鎖的機(jī)制,可以一直讀(在寫數(shù)據(jù)的時候也可以),但是每次讀的時候會有個版本的標(biāo)記,如果本次讀的版本低于緩存的版本,會重新讀數(shù)據(jù),這樣的情況并不多,可以忍受。Session與CookieSession與Cookie:Cookie可以讓服務(wù)端跟蹤每個客戶端的訪問,但是每次客戶端的訪問都必須傳回這些Cookie,如果Cookie很多,則無形的增加了客戶端與服務(wù)端的數(shù)據(jù)傳輸量,而Session則很好地解決了這個問題,同一個客戶端每次和服務(wù)端交互時,將數(shù)據(jù)存儲通過Session到服務(wù)端,不需要每次都傳回所有的Cookie值,而是傳回一個ID,每個客戶端第一次訪問服務(wù)器生成的唯一的ID,客戶端只要傳回這個ID就行了,這個ID通常為NAME為JSESSIONID的一個Cookie。這樣服務(wù)端就可以通過這個ID,來將存儲到服務(wù)端的KV值取出了。分布式Session框架1、配置服務(wù)器,Zookeeper集群管理服務(wù)器可以統(tǒng)一管理所有服務(wù)器的配置文件;2、共享這些Session存儲在一個分布式緩存中,可以隨時寫入和讀取,而且性能要很好,如Memcache,Tair;3、封裝一個類繼承自HttpSession,將Session存入到這個類中然后再存入分布式緩存中;4、由于Cookie不能跨域訪問,要實(shí)現(xiàn)Session同步,要同步SessionID寫到不同域名下。InputStream適配器模式:將一個接口適配到另一個接口,JavaI/O中InputStreamReader將Reader類適配到InputStream,從而實(shí)現(xiàn)了字節(jié)流到字符流的準(zhǔn)換。裝飾者模式:保持原來的接口,增強(qiáng)原來有的功能。FileInputStream實(shí)現(xiàn)了InputStream的所有接口,BufferedInputStreams繼承自FileInputStream是具體的裝飾器實(shí)現(xiàn)者,將InputStream讀取的內(nèi)容保存在內(nèi)存中,而提高讀取的性能。Spring事務(wù)配置方法1、切點(diǎn)信息,用于定位實(shí)施事物切面的業(yè)務(wù)類方法。2、控制事務(wù)行為的事務(wù)屬性,這些屬性包括事物隔離級別,事務(wù)傳播行為,超時時間,回滾規(guī)則。Spring通過aop/txSchema命名空間和@Transaction注解技術(shù)來進(jìn)行聲明式事物配置。Mybatis每一個Mybatis的應(yīng)用程序都以一個SqlSessionFactory對象的實(shí)例為核心。首先用字節(jié)流通過Resource將配置文件讀入。通過SqlSessionFactoryBuilder().build方法創(chuàng)建SqlSessionFactory,然后再通過SqlSessionFactory.openSession()方法創(chuàng)建一個SqlSession為每一個數(shù)據(jù)庫事務(wù)服務(wù)。經(jīng)歷了Mybatis初始化–>創(chuàng)建SqlSession–>運(yùn)行SQL語句,返回結(jié)果三個過程。Servlet和Filter的區(qū)別整的流程是:Filter對用戶請求進(jìn)行預(yù)處理,接著將請求交給Servlet進(jìn)行處理并生成響應(yīng),最后Filter再對服務(wù)器響應(yīng)進(jìn)行后處理。Filter有如下幾個用處:Filter可以進(jìn)行對特定的url請求和相應(yīng)做預(yù)處理和后處理。在HttpServletRequest到達(dá)Servlet之前,攔截客戶的HttpServletRequest。根據(jù)需要檢查HttpServletRequest,也可以修改HttpServletRequest頭和數(shù)據(jù)。在HttpServletResponse到達(dá)客戶端之前,攔截HttpServletResponse。根據(jù)需要檢查HttpServletResponse,也可以修改HttpServletResponse頭和數(shù)據(jù)。實(shí)際上Filter和Servlet極其相似,區(qū)別只是Filter不能直接對用戶生成響應(yīng)。實(shí)際上Filter里doFilter()方法里的代碼就是從多個Servlet的service()方法里抽取的通用代碼,通過使用Filter可以實(shí)現(xiàn)更好的復(fù)用。Filter和Servlet的生命周期:1、Filter在web服務(wù)器啟動時初始化。2、如果某個Servlet配置了1,該Servlet也是在Tomcat(Servlet容器)啟動時初始化。3、如果Servlet沒有配置1,該Servlet不會在Tomcat啟動時初始化,而是在請求到來時初始化。4、每次請求,Request都會被初始化,響應(yīng)請求后,請求被銷毀。5、Servlet初始化后,將不會隨著請求的結(jié)束而注銷。6、關(guān)閉Tomcat時,Servlet、Filter依次被注銷。HashMap與HashTable的區(qū)別1、HashMap是非線程安全的,HashTable是線程安全的。2、HashMap的鍵和值都允許有null值存在,而HashTable則不行。3、因?yàn)榫€程安全的問題,HashMap效率比HashTable的要高。HashMap的實(shí)現(xiàn)機(jī)制:1、維護(hù)一個每個元素是一個鏈表的數(shù)組,而且鏈表中的每個節(jié)點(diǎn)是一個Entry[]鍵值對的數(shù)據(jù)結(jié)構(gòu)。2、實(shí)現(xiàn)了數(shù)組+鏈表的特性,查找快,插入刪除也快。3、對于每個key,他對應(yīng)的數(shù)組索引下標(biāo)是inti=hash(key.hashcode)&(len-1);4、每個新加入的節(jié)點(diǎn)放在鏈表首,然后該新加入的節(jié)點(diǎn)指向原鏈表首。Linux常用命令cd,cp,mv,rm,ps(進(jìn)程),tar,cat(查看內(nèi)容),chmod,vim,find,ls死鎖的必要條件1、互斥至少有一個資源處于非共享狀態(tài);2、占有并等待;3、非搶占;4、循環(huán)等待。解決死鎖,第一個是死鎖預(yù)防,就是不讓上面的四個條件同時成立。二是,合理分配資源。三是使用銀行家算法,如果該進(jìn)程請求的資源操作系統(tǒng)剩余量可以滿足,那么就分配。進(jìn)程間的通信方式管道(pipe):管道是一種半雙工的通信方式,數(shù)據(jù)只能單向流動,而且只能在具有親緣關(guān)系的進(jìn)程間使用。進(jìn)程的親緣關(guān)系通常是指父子進(jìn)程關(guān)系。有名管道(namedpipe):有名管道也是半雙工的通信方式,但是它允許無親緣關(guān)系進(jìn)程間的通信。信號量(semophore):信號量是一個計(jì)數(shù)器,可以用來控制多個進(jìn)程對共享資源的訪問。它常作為一種鎖機(jī)制,防止某進(jìn)程正在訪問共享資源時,其他進(jìn)程也訪問該資源。因此,主要作為進(jìn)程間以及同一進(jìn)程內(nèi)不同線程之間的同步手段。消息隊(duì)列(messagequeue):消息隊(duì)列是由消息的鏈表,存放在內(nèi)核中并由消息隊(duì)列標(biāo)識符標(biāo)識。消息隊(duì)列克服了信號傳遞信息少、管道只能承載無格式字節(jié)流以及緩沖區(qū)大小受限等缺點(diǎn)。信號(sinal):信號是一種比較復(fù)雜的通信方式,用于通知接收進(jìn)程某個事件已經(jīng)發(fā)生。共享內(nèi)存(sharedmemory):共享內(nèi)存就是映射一段能被其他進(jìn)程所訪問的內(nèi)存,這段共享內(nèi)存由一個進(jìn)程創(chuàng)建,但多個進(jìn)程都可以訪問。共享內(nèi)存是最快的IPC方式,它是針對其他進(jìn)程間通信方式運(yùn)行效率低而專門設(shè)計(jì)的。它往往與其他通信機(jī)制,如信號量,配合使用,來實(shí)現(xiàn)進(jìn)程間的同步和通信。套接字(socket):套解口也是一種進(jìn)程間通信機(jī)制,與其他通信機(jī)制不同的是,它可用于不同機(jī)器間的進(jìn)程通信。Switch能否用string做參數(shù)?在Java7之前,switch只能支持byte、short、char、int或者其對應(yīng)的封裝類以及Enum類型。在Java7中、String支持被加上了。Object有哪些公用方法?a、方法equals測試的是兩個對象是否相等;b、方法clone進(jìn)行對象拷貝;c、方法getClass返回和當(dāng)前對象相關(guān)的Class對象;d、方法notify,notifyall,wait都是用來對給定對象進(jìn)行線程同步的。Java的四種引用,強(qiáng)弱軟虛,以及用到的場景利用軟引用和弱引用解決OOM問題:用一個HashMap來保存圖片的路徑和相應(yīng)圖片對象關(guān)聯(lián)的軟引用之間的映射關(guān)系,在內(nèi)存不足時,JVM會自動回收這些緩存圖片對象所占用的空間,從而有效地避免了OOM的問題。通過軟可及對象重獲方法實(shí)現(xiàn)Java對象的高速緩存:比如我們創(chuàng)建了一Employee的類,如果每次需要查詢一個雇員的信息。哪怕是幾秒中之前剛剛查詢過的,都要重新構(gòu)建一個實(shí)例,這是需要消耗很多時間的。我們可以通過軟引用和HashMap的結(jié)合,先是保存引用方面:以軟引用的方式對一個Employee對象的實(shí)例進(jìn)行引用并保存該引用到HashMap上,key為此雇員的id,value為這個對象的軟引用,另一方面是取出引用,緩存中是否有該Employee實(shí)例的軟引用,如果有,從軟引用中取得。如果沒有軟引用,或者從軟引用中得到的實(shí)例是null,重新構(gòu)建一個實(shí)例,并保存對這個新建實(shí)例的軟引用。強(qiáng)引用:如果一個對象具有強(qiáng)引用,它就不會被垃圾回收器回收。即使當(dāng)前內(nèi)存空間不足,JVM也不會回收它,而是拋出OutOfMemoryError錯誤,使程序異常終止。如果想中斷強(qiáng)引用和某個對象之間的關(guān)聯(lián),可以顯式地將引用賦值為null,這樣一來的話,JVM在合適的時間就會回收該對象。軟引用:在使用軟引用時,如果內(nèi)存的空間足夠,軟引用就能繼續(xù)被使用,而不會被垃圾回收器回收,只有在內(nèi)存不足時,軟引用才會被垃圾回收器回收。弱引用:具有弱引用的對象擁有的生命周期更短暫。因?yàn)楫?dāng)JVM進(jìn)行垃圾回收,一旦發(fā)現(xiàn)弱引用對象,無論當(dāng)前內(nèi)存空間是否充足,都會將弱引用回收。不過由于垃圾回收器是一個優(yōu)先級較低的線程,所以并不一定能迅速發(fā)現(xiàn)弱引用對象。虛引用:顧名思義,就是形同虛設(shè),如果一個對象僅持有虛引用,那么它相當(dāng)于沒有引用,在任何時候都可能被垃圾回收器回收。Hashcode的作用,與equal有什么區(qū)別?同樣用于鑒定2個對象是否相等的,java集合中有l(wèi)ist和set兩類,其中set不允許元素重復(fù)實(shí)現(xiàn),那個這個不允許重復(fù)實(shí)現(xiàn)的方法,如果用equal去比較的話,如果存在1000個元素,你new一個新的元素出來,需要去調(diào)用1000次equal去逐個和他們比較是否是同一個對象,這樣會大大降低效率。hashcode實(shí)際上是返回對象的存儲地址,如果這個位置上沒有元素,就把元素直接存儲在上面,如果這個位置上已經(jīng)存在元素,這個時候才去調(diào)用equal方法與新元素進(jìn)行比較,相同的話就不存了,散列到其他地址上。Override和Overload的含義以及區(qū)別a、Overload顧名思義是重新加載,它可以表現(xiàn)類的多態(tài)性,可以是函數(shù)里面可以有相同的函數(shù)名但是參數(shù)名、返回值、類型不能相同;或者說可以改變參數(shù)、類型、返回值但是函數(shù)名字依然不變。b、就是ride(重寫)的意思,在子類繼承父類的時候子類中可以定義某方法與其父類有相同的名稱和參數(shù),當(dāng)子類在調(diào)用這一函數(shù)時自動調(diào)用子類的方法,而父類相當(dāng)于被覆蓋(重寫)了。具體可前往C++中重載、重寫(覆蓋)的區(qū)別實(shí)例分析查看。抽象類和接口的區(qū)別a、一個類只能繼承單個類,但是可以實(shí)現(xiàn)多個接口;b、抽象類中可以有構(gòu)造方法,接口中不能有構(gòu)造方法;c、抽象類中的所有方法并不一定要是抽象的,你可以選擇在抽象類中實(shí)現(xiàn)一些基本的方法。而接口要求所有的方法都必須是抽象的;d、
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025項(xiàng)目管理聘用合同內(nèi)容
- 《2025自動化設(shè)備采購合同》
- 青島房屋過戶合同范本
- 2025《合同法》與企業(yè)管理:應(yīng)對新挑戰(zhàn)實(shí)現(xiàn)共贏
- 語言藝術(shù)訓(xùn)練知到課后答案智慧樹章節(jié)測試答案2025年春青島職業(yè)技術(shù)學(xué)院
- 2025授權(quán)人力資源服務(wù)合同
- 2024年廈門醫(yī)院招聘事業(yè)單位專業(yè)技術(shù)人員真題
- 2024年南昌市市屬事業(yè)單位考試真題
- 2024年灤州市市屬事業(yè)單位考試真題
- 2024年安吉縣上墅私立職業(yè)高級中學(xué)專任教師招聘真題
- 山東省國控設(shè)計(jì)集團(tuán)有限公司招聘筆試真題2024
- 《民航飛機(jī)航電設(shè)備故障檢測與診斷》全套教學(xué)課件
- 2024年山東水利技師學(xué)院招聘初級專業(yè)技術(shù)崗位人員考試真題
- 2024年廣東公需課《百縣千鎮(zhèn)萬村高質(zhì)量發(fā)展工程與城鄉(xiāng)區(qū)域協(xié)調(diào)發(fā)展》試題及答案
- 2024年山東省濟(jì)南市中考數(shù)學(xué)模擬試卷(三)(含答案)
- (正式版)SHT 3046-2024 石油化工立式圓筒形鋼制焊接儲罐設(shè)計(jì)規(guī)范
- 志愿服務(wù)證明(多模板)
- 教學(xué)課件·植物組織培養(yǎng)
- 部編版語文一年級下冊識字8-人之初市級優(yōu)質(zhì)課課件
- 基于仿真的軸承動力學(xué)分析設(shè)計(jì)畢業(yè)設(shè)計(jì)說明書
- 麗聲北極星分級繪本第二級下Eek,Spider 教學(xué)設(shè)計(jì)
評論
0/150
提交評論