更新時間:2020-07-16 10:35:09 來源:動力節(jié)點 瀏覽2233次
有很多人都很向往深圳這個城市,在深圳有很多的互聯(lián)網(wǎng)企業(yè),市場對java開發(fā)人才需求非常大,對于年輕人來說,去深圳發(fā)展也是一個不錯的選擇。要想應(yīng)聘java程序員,就會遇到面試題的問題。那么,深圳java各公司面試題哪里有?這個問題就由動力節(jié)點深圳java培訓(xùn)機構(gòu)的小編來為大家解答。
深圳java面試題哪里有?小編為大家做了以下java面試題的整理,希望對大家能夠有所幫助。
Java虛擬機規(guī)范中將Java運行時數(shù)據(jù)分為六種。
(1)程序計數(shù)器:是一個數(shù)據(jù)結(jié)構(gòu),用于保存當(dāng)前正常執(zhí)行的程序的內(nèi)存地址。Java虛擬機的多線程就是通過線程輪流切換并分配處理器時間來實現(xiàn)的,為了線程切換后能恢復(fù)到正確的位置,每條線程都需要一個獨立的程序計數(shù)器,互不影響,該區(qū)域為“線程私有”。
(2)Java虛擬機棧:線程私有的,與線程生命周期相同,用于存儲局部變量表,操作棧,方法返回值。局部變量表放著基本數(shù)據(jù)類型,還有對象的引用。
(3)本地方法棧:跟虛擬機棧很像,不過它是為虛擬機使用到的Native方法服務(wù)。
(4)Java堆:所有線程共享的一塊內(nèi)存區(qū)域,對象實例幾乎都在這分配內(nèi)存。
(5)方法區(qū):各個線程共享的區(qū)域,儲存虛擬機加載的類信息,常量,靜態(tài)變量,編譯后的代碼。
(6)運行時常量池:代表運行時每個class文件中的常量表。包括幾種常量:編譯時的數(shù)字常量、方法或者域的引用。
在什么時候:
(1)新生代有一個Eden區(qū)和兩個survivor區(qū),首先將對象放入Eden區(qū),如果空間不足就向其中的一個survivor區(qū)上放,如果仍然放不下就會引發(fā)一次發(fā)生在新生代的minor GC,將存活的對象放入另一個survivor區(qū)中,然后清空Eden和之前的那個survivor區(qū)的內(nèi)存。在某次GC過程中,如果發(fā)現(xiàn)仍然又放不下的對象,就將這些對象放入老年代內(nèi)存里去。
(2)大對象以及長期存活的對象直接進入老年區(qū)。
(3)當(dāng)每次執(zhí)行minor GC的時候應(yīng)該對要晉升到老年代的對象進行分析,如果這些馬上要到老年區(qū)的老年對象的大小超過了老年區(qū)的剩余大小,那么執(zhí)行一次Full GC以盡可能地獲得老年區(qū)的空間。
對什么東西:從GC Roots搜索不到,而且經(jīng)過一次標(biāo)記清理之后仍沒有復(fù)活的對象。
做什么: 新生代:復(fù)制清理; 老年代:標(biāo)記-清除和標(biāo)記-壓縮算法; 永久代:存放Java中的類和加載類的類加載器本身。
GC Roots都有哪些: 1. 虛擬機棧中的引用的對象 2. 方法區(qū)中靜態(tài)屬性引用的對象,常量引用的對象 3. 本地方法棧中JNI(即一般說的Native方法)引用的對象。
Synchronized是悲觀鎖機制,獨占鎖。而Locks.ReentrantLock是,每次不加鎖而是假設(shè)沒有沖突而去完成某項操作,如果因為沖突失敗就重試,直到成功為止。 ReentrantLock適用場景
(1)某個線程在等待一個鎖的控制權(quán)的這段時間需要中斷
(2)需要分開處理一些wait-notify,ReentrantLock里面的Condition應(yīng)用,能夠控制notify哪個線程,鎖可以綁定多個條件。
(3)具有公平鎖功能,每個到來的線程都將排隊等候。
(1)程序順序規(guī)則:一個線程中的每個操作,happens- before 于該線程中的任意后續(xù)操作。
(2)監(jiān)視器鎖規(guī)則:對一個監(jiān)視器鎖的解鎖,happens- before 于隨后對這個監(jiān)視器鎖的加鎖。
(3)volatile變量規(guī)則:對一個volatile域的寫,happens- before于任意后續(xù)對這個volatile域的讀。
(4)傳遞性:如果A happens- before B,且B happens- before C,那么A happens- before C。
(5)線程啟動規(guī)則:Thread對象的start()方法happens- before于此線程的每一個動作。
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 是主要的實現(xiàn)類,其中常用的有 Executors.newSingleThreadPool(),newFixedThreadPool(),newcachedTheadPool(),newScheduledThreadPool()。
Hash—字典(hashmap) Redis的哈希結(jié)構(gòu)可以使你像在數(shù)據(jù)庫中更新一個屬性一樣只修改某一項屬性值
List—列表 實現(xiàn)消息隊列
Set—集合 利用唯一性
Sorted Set—有序集合 可以進行排序 可以實現(xiàn)數(shù)據(jù)持久化
(1)切點信息,用于定位實施事物切面的業(yè)務(wù)類方法
(2)控制事務(wù)行為的事務(wù)屬性,這些屬性包括事物隔離級別,事務(wù)傳播行為,超時時間,回滾規(guī)則。
Spring通過aop/tx Schema 命名空間和@Transaction注解技術(shù)來進行聲明式事物配置。
每一個Mybatis的應(yīng)用程序都以一個SqlSessionFactory對象的實例為核心。首先用字節(jié)流通過Resource將配置文件讀入,然后通過SqlSessionFactoryBuilder().build方法創(chuàng)建SqlSessionFactory,然后再通過SqlSessionFactory.openSession()方法創(chuàng)建一個SqlSession為每一個數(shù)據(jù)庫事務(wù)服務(wù)。
經(jīng)歷了Mybatis初始化 –>創(chuàng)建SqlSession –>運行SQL語句,返回結(jié)果三個過程
(1)HashMap是非線程安全的,HashTable是線程安全的。
(2)HashMap的鍵和值都允許有null值存在,而HashTable則不行。
(3)因為線程安全的問題,HashMap效率比HashTable的要高。
以上就是動力節(jié)點深圳java培訓(xùn)機構(gòu)的小編針對“深圳java各公司面試題哪里有?”的內(nèi)容進行的回答,希望對大家有所幫助,如有疑問,請在線咨詢,有專業(yè)老師隨時為你服務(wù)。
相關(guān)閱讀
初級 202925
初級 203221
初級 202629
初級 203743