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