Java後端開發常見面試題目匯總

2020-12-13 CSDN

ThreadLocal(線程變量副本)

Synchronized實現內存共享,ThreadLocal為每個線程維護一個本地變量。

採用空間換時間,它用於線程間的數據隔離,為每一個使用該變量的線程提供一個副本,每個線程都可以獨立地改變自己的副本,而不會和其他線程的副本衝突。

ThreadLocal類中維護一個Map,用於存儲每一個線程的變量副本,Map中元素的鍵為線程對象,而值為對應線程的變量副本。

ThreadLocal在Spring中發揮著巨大的作用,在管理Request作用域中的Bean、事務管理、任務調度、AOP等模塊都出現了它的身影。

Spring中絕大部分Bean都可以聲明成Singleton作用域,採用ThreadLocal進行封裝,因此有狀態的Bean就能夠以singleton的方式在多線程中正常工作了。

友情連結:深入研究java.lang.ThreadLocal類

Java內存模型:

Java虛擬機規範中將Java運行時數據分為六種。

1.程序計數器:是一個數據結構,用於保存當前正常執行的程序的內存地址。Java虛擬機的多線程就是通過線程輪流切換並分配處理器時間來實現的,為了線程切換後能恢復到正確的位置,每條線程都需要一個獨立的程序計數器,互不影響,該區域為「線程私有」。

2.Java虛擬機棧:線程私有的,與線程生命周期相同,用於存儲局部變量表,操作棧,方法返回值。局部變量表放著基本數據類型,還有對象的引用。

3.本地方法棧:跟虛擬機棧很像,不過它是為虛擬機使用到的Native方法服務。

4.Java堆:所有線程共享的一塊內存區域,對象實例幾乎都在這分配內存。

5.方法區:各個線程共享的區域,儲存虛擬機加載的類信息,常量,靜態變量,編譯後的代碼。

6.運行時常量池:代表運行時每個class文件中的常量表。包括幾種常量:編譯時的數字常量、方法或者域的引用。

友情連結: Java中JVM虛擬機詳解

「你能不能談談,java GC是在什麼時候,對什麼東西,做了什麼事情?」

在什麼時候:

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方法)引用的對象。

友情連結:Java GC的那些事(上)

友情連結:Java GC的那些事(下)

友情連結:CMS垃圾收集器介紹

Synchronized 與Lock都是可重入鎖,同一個線程再次進入同步代碼的時候.可以使用自己已經獲取到的鎖。

Synchronized是悲觀鎖機制,獨佔鎖。而Locks.ReentrantLock是,每次不加鎖而是假設沒有衝突而去完成某項操作,如果因為衝突失敗就重試,直到成功為止。 ReentrantLock適用場景

某個線程在等待一個鎖的控制權的這段時間需要中斷

需要分開處理一些wait-notify,ReentrantLock裡面的Condition應用,能夠控制notify哪個線程,鎖可以綁定多個條件。

具有公平鎖功能,每個到來的線程都將排隊等候。

友情連結: Synchronized關鍵字、Lock,並解釋它們之間的區別

StringBuffer是線程安全的,每次操作字符串,String會生成一個新的對象,而StringBuffer不會;StringBuilder是非線程安全的

友情連結:String、StringBuffer與StringBuilder之間區別

fail-fast:機制是java集合(Collection)中的一種錯誤機制。當多個線程對同一個集合的內容進行操作時,就可能會產生fail-fast事件。

例如:當某一個線程A通過iterator去遍歷某集合的過程中,若該集合的內容被其他線程所改變了;那麼線程A訪問集合時,就會拋出ConcurrentModificationException異常,產生fail-fast事件

happens-before:如果兩個操作之間具有happens-before 關係,那麼前一個操作的結果就會對後面一個操作可見。

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於此線程的每一個動作。

Volatile和Synchronized四個不同點:

1 粒度不同,前者針對變量 ,後者鎖對象和類

2 syn阻塞,volatile線程不阻塞

3 syn保證三大特性,volatile不保證原子性

4 syn編譯器優化,volatile不優化 volatile具備兩種特性:

1.保證此變量對所有線程的可見性,指一條線程修改了這個變量的值,新值對於其他線程來說是可見的,但並不是多線程安全的。

2.禁止指令重排序優化。

Volatile如何保證內存可見性:

1.當寫一個volatile變量時,JMM會把該線程對應的本地內存中的共享變量刷新到主內存。

2.當讀一個volatile變量時,JMM會把該線程對應的本地內存置為無效。線程接下來將從主內存中讀取共享變量。

同步:就是一個任務的完成需要依賴另外一個任務,只有等待被依賴的任務完成後,依賴任務才能完成。

異步:不需要等待被依賴的任務完成,只是通知被依賴的任務要完成什麼工作,只要自己任務完成了就算完成了,被依賴的任務是否完成會通知回來。(異步的特點就是通知)。 打電話和發簡訊來比喻同步和異步操作。

阻塞:CPU停下來等一個慢的操作完成以後,才會接著完成其他的工作。

非阻塞:非阻塞就是在這個慢的執行時,CPU去做其他工作,等這個慢的完成後,CPU才會接著完成後續的操作。

非阻塞會造成線程切換增加,增加CPU的使用時間能不能補償系統的切換成本需要考慮。

友情連結:Java並發編程之volatile關鍵字解析

CAS(Compare And Swap) 無鎖算法: CAS是樂觀鎖技術,當多個線程嘗試使用CAS同時更新同一個變量時,只有其中一個線程能更新變量的值,而其它線程都失敗,失敗的線程並不會被掛起,而是被告知這次競爭中失敗,並可以再次嘗試。CAS有3個操作數,內存值V,舊的預期值A,要修改的新值B。若且唯若預期值A和內存值V相同時,將內存值V修改為B,否則什麼都不做。

友情連結:非阻塞同步算法與CAS(Compare and Swap)無鎖算法

Java後端開發常見面試題目匯總

線程池的作用: 在程序啟動的時候就創建若干線程來響應處理,它們被稱為線程池,裡面的線程叫工作線程

第一:降低資源消耗。通過重複利用已創建的線程降低線程創建和銷毀造成的消耗。

第二:提高響應速度。當任務到達時,任務可以不需要等到線程創建就能立即執行。

第三:提高線程的可管理性。

常用線程池:ExecutorService 是主要的實現類,其中常用的有 Executors.newSingleThreadPool(),newFixedThreadPool(),newcachedTheadPool(),newScheduledThreadPool()。

友情連結:線程池原理

友情連結:線程池原理解析

類加載器工作機制:

1.裝載:將Java二進位代碼導入jvm中,生成Class文件。

2.連接:a)校驗:檢查載入Class文件數據的正確性 b)準備:給類的靜態變量分配存儲空間 c)解析:將符號引用轉成直接引用

3:初始化:對類的靜態變量,靜態方法和靜態代碼塊執行初始化工作。

雙親委派模型:類加載器收到類加載請求,首先將請求委派給父類加載器完成 用戶自定義加載器->應用程式加載器->擴展類加載器->啟動類加載器。

友情連結:深入理解Java虛擬機筆記—雙親委派模型

友情連結:JVM類加載的那些事

友情連結:JVM(1):Java 類的加載機制

一致性哈希:

Memcahed緩存:

數據結構:key,value對

使用方法:get,put等方法

友情連結:hashcode(),equal()方法深入解析

Redis數據結構: String—字符串(key-value 類型)

Hash—字典(hashmap) Redis的哈希結構可以使你像在資料庫中更新一個屬性一樣只修改某一項屬性值

List—列表 實現消息隊列

Set—集合 利用唯一性

Sorted Set—有序集合 可以進行排序 可以實現數據持久化

友情連結: Spring + Redis 實現數據的緩存

java自動裝箱拆箱深入剖析

談談Java反射機制

如何寫一個不可變類?

索引:B+,B-,全文索引

Mysql的索引是一個數據結構,旨在使資料庫高效的查找數據。

常用的數據結構是B+Tree,每個葉子節點不但存放了索引鍵的相關信息還增加了指向相鄰葉子節點的指針,這樣就形成了帶有順序訪問指針的B+Tree,做這個優化的目的是提高不同區間訪問的性能。

什麼時候使用索引:

經常出現在group by,order by和distinc關鍵字後面的欄位

經常與其他表進行連接的表,在連接欄位上應該建立索引

經常出現在Where子句中的欄位

經常出現用作查詢選擇的欄位

友情連結:MySQL:InnoDB存儲引擎的B+樹索引算法

友情連結:MySQL索引背後的數據結構及算法原理

Spring IOC (控制反轉,依賴注入)

Spring支持三種依賴注入方式,分別是屬性(Setter方法)注入,構造注入和接口注入。

在Spring中,那些組成應用的主體及由Spring IOC容器所管理的對象被稱之為Bean。

Spring的IOC容器通過反射的機制實例化Bean並建立Bean之間的依賴關係。

簡單地講,Bean就是由Spring IOC容器初始化、裝配及被管理的對象。

獲取Bean對象的過程,首先通過Resource加載配置文件並啟動IOC容器,然後通過getBean方法獲取bean對象,就可以調用他的方法。

Spring Bean的作用域:

Singleton:Spring IOC容器中只有一個共享的Bean實例,一般都是Singleton作用域。

Prototype:每一個請求,會產生一個新的Bean實例。

Request:每一次http請求會產生一個新的Bean實例。

友情連結: Spring框架IOC容器和AOP解析

友情連結:淺談Spring框架註解的用法分析

友情連結:關於Spring的69個面試問答——終極列表

代理的共有優點:業務類只需要關注業務邏輯本身,保證了業務類的重用性。

Java靜態代理:

代理對象和目標對象實現了相同的接口,目標對象作為代理對象的一個屬性,具體接口實現中,代理對象可以在調用目標對象相應方法前後加上其他業務處理邏輯。

缺點:一個代理類只能代理一個業務類。如果業務類增加方法時,相應的代理類也要增加方法。

Java動態代理:

Java動態代理是寫一個類實現InvocationHandler接口,重寫Invoke方法,在Invoke方法可以進行增強處理的邏輯的編寫,這個公共代理類在運行的時候才能明確自己要代理的對象,同時可以實現該被代理類的方法的實現,然後在實現類方法的時候可以進行增強處理。

實際上:代理對象的方法 = 增強處理 + 被代理對象的方法

JDK和CGLIB生成動態代理類的區別:

JDK動態代理只能針對實現了接口的類生成代理(實例化一個類)。此時代理對象和目標對象實現了相同的接口,目標對象作為代理對象的一個屬性,具體接口實現中,可以在調用目標對象相應方法前後加上其他業務處理邏輯

CGLIB是針對類實現代理,主要是對指定的類生成一個子類(沒有實例化一個類),覆蓋其中的方法 。

Spring AOP應用場景

性能檢測,訪問控制,日誌管理,事務等。

默認的策略是如果目標類實現接口,則使用JDK動態代理技術,如果目標對象沒有實現接口,則默認會採用CGLIB代理

SpringMVC運行原理

客戶端請求提交到DispatcherServlet

由DispatcherServlet控制器查詢HandlerMapping,找到並分發到指定的Controller中。

Controller調用業務邏輯處理後,返回ModelAndView

DispatcherServlet查詢一個或多個ViewResoler視圖解析器,找到ModelAndView指定的視圖

視圖負責將結果顯示到客戶端

友情連結:Spring:基於註解的Spring MVC(上)

友情連結: Spring:基於註解的Spring MVC(下)

友情連結:SpringMVC與Struts2區別與比較總結

友情連結:SpringMVC與Struts2的對比

一個Http請求

DNS域名解析 –> 發起TCP的三次握手 –> 建立TCP連接後發起http請求 –> 伺服器響應http請求,瀏覽器得到html代碼 –> 瀏覽器解析html代碼,並請求html代碼中的資源(如javascript、css、圖片等) –> 瀏覽器對頁面進行渲染呈現給用戶

設計存儲海量數據的存儲系統:設計一個叫「中間層」的一個邏輯層,在這個層,將資料庫的海量數據抓出來,做成緩存,運行在伺服器的內存中,同理,當有新的數據到來,也先做成緩存,再想辦法,持久化到資料庫中,這是一個簡單的思路。主要的步驟是負載均衡,將不同用戶的請求分發到不同的處理節點上,然後先存入緩存,定時向主資料庫更新數據。讀寫的過程採用類似樂觀鎖的機制,可以一直讀(在寫數據的時候也可以),但是每次讀的時候會有個版本的標記,如果本次讀的版本低於緩存的版本,會重新讀數據,這樣的情況並不多,可以忍受。

友情連結: HTTP與HTTPS的區別

友情連結: HTTPS 為什麼更安全,先看這些

友情連結: HTTP請求報文和HTTP響應報文

友情連結: HTTP 請求方式: GET和POST的比較

Session與Cookie:Cookie可以讓服務端跟蹤每個客戶端的訪問,但是每次客戶端的訪問都必須傳回這些Cookie,如果Cookie很多,則無形的增加了客戶端與服務端的數據傳輸量,

而Session則很好地解決了這個問題,同一個客戶端每次和服務端交互時,將數據存儲通過Session到服務端,不需要每次都傳回所有的Cookie值,而是傳回一個ID,每個客戶端第一次訪問伺服器生成的唯一的ID,客戶端只要傳回這個ID就行了,這個ID通常為NAME為JSESSIONID的一個Cookie。這樣服務端就可以通過這個ID,來將存儲到服務端的KV值取出了。

Session和Cookie的超時問題,Cookie的安全問題

分布式Session框架

配置伺服器,Zookeeper集群管理伺服器可以統一管理所有伺服器的配置文件

共享這些Session存儲在一個分布式緩存中,可以隨時寫入和讀取,而且性能要很好,如Memcache,Tair。

封裝一個類繼承自HttpSession,將Session存入到這個類中然後再存入分布式緩存中

由於Cookie不能跨域訪問,要實現Session同步,要同步SessionID寫到不同域名下。

適配器模式:將一個接口適配到另一個接口,Java I/O中InputStreamReader將Reader類適配到InputStream,從而實現了字節流到字符流的準換。

裝飾者模式:保持原來的接口,增強原來有的功能。

FileInputStream 實現了InputStream的所有接口,BufferedInputStreams繼承自FileInputStream是具體的裝飾器實現者,將InputStream讀取的內容保存在內存中,而提高讀取的性能。

Spring事務配置方法:

1.切點信息,用於定位實施事物切面的業務類方法

2.控制事務行為的事務屬性,這些屬性包括事物隔離級別,事務傳播行為,超時時間,回滾規則。

Spring通過aop/tx Schema 命名空間和@Transaction註解技術來進行聲明式事物配置。

Mybatis

每一個Mybatis的應用程式都以一個SqlSessionFactory對象的實例為核心。首先用字節流通過Resource將配置文件讀入,然後通過SqlSessionFactoryBuilder().build方法創建SqlSessionFactory,然後再通過SqlSessionFactory.openSession()方法創建一個SqlSession為每一個資料庫事務服務。

經歷了Mybatis初始化 –>創建SqlSession –>運行SQL語句,返回結果三個過程

Servlet和Filter的區別:

整的流程是:Filter對用戶請求進行預處理,接著將請求交給Servlet進行處理並生成響應,最後Filter再對伺服器響應進行後處理。

Filter有如下幾個用處:

Filter可以進行對特定的url請求和相應做預處理和後處理。

在HttpServletRequest到達Servlet之前,攔截客戶的HttpServletRequest。

根據需要檢查HttpServletRequest,也可以修改HttpServletRequest頭和數據。

在HttpServletResponse到達客戶端之前,攔截HttpServletResponse。

根據需要檢查HttpServletResponse,也可以修改HttpServletResponse頭和數據。

實際上Filter和Servlet極其相似,區別只是Filter不能直接對用戶生成響應。實際上Filter裡doFilter()方法裡的代碼就是從多個Servlet的service()方法裡抽取的通用代碼,通過使用Filter可以實現更好的復用。

Filter和Servlet的生命周期:

1.Filter在web伺服器啟動時初始化

2.如果某個Servlet配置了 1 ,該Servlet也是在Tomcat(Servlet容器)啟動時初始化。

3.如果Servlet沒有配置1 ,該Servlet不會在Tomcat啟動時初始化,而是在請求到來時初始化。

4.每次請求, Request都會被初始化,響應請求後,請求被銷毀。

5.Servlet初始化後,將不會隨著請求的結束而註銷。

6.關閉Tomcat時,Servlet、Filter依次被註銷。

HashMap與HashTable的區別。

1、HashMap是非線程安全的,HashTable是線程安全的。

2、HashMap的鍵和值都允許有null值存在,而HashTable則不行。

3、因為線程安全的問題,HashMap效率比HashTable的要高。

HashMap的實現機制:

維護一個每個元素是一個鍊表的數組,而且鍊表中的每個節點是一個Entry[]鍵值對的數據結構。

實現了數組+鍊表的特性,查找快,插入刪除也快。

對於每個key,他對應的數組索引下標是 int i = hash(key.hashcode)&(len-1);

每個新加入的節點放在鍊表首,然後該新加入的節點指向原鍊表首

HashMap和TreeMap區別

友情連結: Java中HashMap和TreeMap的區別深入理解

HashMap衝突

友情連結: HashMap衝突的解決方法以及原理分析

友情連結: HashMap的工作原理

友情連結: HashMap和Hashtable的區別

友情連結: 2種辦法讓HashMap線程安全

如果你正在找工作或者剛剛學校出來,又或者已經工作但是經常覺得難點很多,覺得自己java方面學的不夠精想要繼續學習的,想轉行怕學不會的,可以加Q3300863615 了解諮詢java繼續學習。更有免費視頻等你來領取。

HashMap,ConcurrentHashMap與LinkedHashMap的區別

ConcurrentHashMap是使用了鎖分段技術技術來保證線程安全的,鎖分段技術:首先將數據分成一段一段的存儲,然後給每一段數據配一把鎖,當一個線程佔用鎖訪問其中一個段數據的時候,其他段的數據也能被其他線程訪問

ConcurrentHashMap 是在每個段(segment)中線程安全的

LinkedHashMap維護一個雙鍊表,可以將裡面的數據按寫入的順序讀出

ConcurrentHashMap應用場景

1:ConcurrentHashMap的應用場景是高並發,但是並不能保證線程安全,而同步的HashMap和HashMap的是鎖住整個容器,而加鎖之後ConcurrentHashMap不需要鎖住整個容器,只需要鎖住對應的Segment就好了,所以可以保證高並發同步訪問,提升了效率。

2:可以多線程寫。

ConcurrentHashMap把HashMap分成若干個Segmenet

1.get時,不加鎖,先定位到segment然後在找到頭結點進行讀取操作。而value是volatile變量,所以可以保證在競爭條件時保證讀取最新的值,如果讀到的value是null,則可能正在修改,那麼就調用ReadValueUnderLock函數,加鎖保證讀到的數據是正確的。

2.Put時會加鎖,一律添加到hash鏈的頭部。

3.Remove時也會加鎖,由於next是final類型不可改變,所以必須把刪除的節點之前的節點都複製一遍。

4.ConcurrentHashMap允許多個修改操作並發進行,其關鍵在於使用了鎖分離技術。它使用了多個鎖來控制對Hash表的不同Segment進行的修改。

ConcurrentHashMap的應用場景是高並發,但是並不能保證線程安全,而同步的HashMap和HashTable的是鎖住整個容器,而加鎖之後ConcurrentHashMap不需要鎖住整個容器,只需要鎖住對應的segment就好了,所以可以保證高並發同步訪問,提升了效率。

ConcurrentHashMap能夠保證每一次調用都是原子操作,但是並不保證多次調用之間也是原子操作。

友情連結:Java集合—ConcurrentHashMap原理分析

Vector和ArrayList的區別

友情連結:Java中Vector和ArrayList的區別

ExecutorService service = Executors…. ExecutorService service = new ThreadPoolExecutor() ExecutorService service = new ScheduledThreadPoolExecutor();

ThreadPoolExecutor源碼分析

線程池本身的狀態:

等待任務隊列和工作集:

線程池的主要狀態鎖:

線程池的存活時間和大小:

1.2 ThreadPoolExecutor 的內部工作原理

有了以上定義好的數據,下面來看看內部是如何實現的 。 Doug Lea 的整個思路總結起來就是 5 句話:

如果當前池大小 poolSize 小於 corePoolSize ,則創建新線程執行任務。

如果當前池大小 poolSize 大於 corePoolSize ,且等待隊列未滿,則進入等待隊列

如果當前池大小 poolSize 大於 corePoolSize 且小於 maximumPoolSize ,且等待隊列已滿,則創建新線程執行任務。

如果當前池大小 poolSize 大於 corePoolSize 且大於 maximumPoolSize ,且等待隊列已滿,則調用拒絕策略來處理該任務。

線程池裡的每個線程執行完任務後不會立刻退出,而是會去檢查下等待隊列裡是否還有線程任務需要執行,如果在 keepAliveTime 裡等不到新的任務了,那麼線程就會退出。

Executor包結構

CopyOnWriteArrayList : 寫時加鎖,當添加一個元素的時候,將原來的容器進行copy,複製出一個新的容器,然後在新的容器裡面寫,寫完之後再將原容器的引用指向新的容器,而讀的時候是讀舊容器的數據,所以可以進行並發的讀,但這是一種弱一致性的策略。

使用場景:CopyOnWriteArrayList適合使用在讀操作遠遠大於寫操作的場景裡,比如緩存。

Linux常用命令:cd,cp,mv,rm,ps(進程),tar,cat(查看內容),chmod,vim,find,ls

死鎖的必要條件

互斥 至少有一個資源處於非共享狀態

佔有並等待

非搶佔

循環等待

解決死鎖,第一個是死鎖預防,就是不讓上面的四個條件同時成立。二是,合理分配資源。

三是使用銀行家算法,如果該進程請求的資源作業系統剩餘量可以滿足,那麼就分配。

進程間的通信方式

管道( pipe ):管道是一種半雙工的通信方式,數據只能單向流動,而且只能在具有親緣關係的進程間使用。進程的親緣關係通常是指父子進程關係。

有名管道 (named pipe) : 有名管道也是半雙工的通信方式,但是它允許無親緣關係進程間的通信。

信號量( semophore ) : 信號量是一個計數器,可以用來控制多個進程對共享資源的訪問。它常作為一種鎖機制,防止某進程正在訪問共享資源時,其他進程也訪問該資源。因此,主要作為進程間以及同一進程內不同線程之間的同步手段。

消息隊列( message queue ) : 消息隊列是由消息的鍊表,存放在內核中並由消息隊列標識符標識。消息隊列克服了信號傳遞信息少、管道只能承載無格式字節流以及緩衝區大小受限等缺點。

信號 ( sinal ) : 信號是一種比較複雜的通信方式,用於通知接收進程某個事件已經發生。

共享內存( shared memory ) :共享內存就是映射一段能被其他進程所訪問的內存,這段共享內存由一個進程創建,但多個進程都可以訪問。共享內存是最快的 IPC 方式,它是針對其他進程間通信方式運行效率低而專門設計的。它往往與其他通信機制,如信號量,配合使用,來實現進程間的同步和通信。

套接字( socket ) : 套解口也是一種進程間通信機制,與其他通信機制不同的是,它可用於不同機器間的進程通信。

想要朝這方面發展或者真心有興趣的。可以找我要一些基礎的學習視頻,Q號碼:3300863615,這個是免費的,希望同學找我要的時候不要有理所應當的態度,畢竟都是我的心血,希望你是真的有一顆想要學好java的心,我也會盡所能的去幫助你成為一名優秀的程式設計師。

進程與線程的區別和聯繫

作業系統的進程調度算法

計算機系統的層次存儲結構詳解

資料庫事務是指作為單個邏輯工作單元執行的一系列操作。

友情連結:資料庫事務的四大特性以及事務的隔離級別

MySQL資料庫優化總結

MYSQL 優化常用方法

MySQL存儲引擎--MyISAM與InnoDB區別

關於SQL資料庫中的範式

Hibernate的一級緩存是由Session提供的,因此它只存在於Session的生命周期中,當程序調用save(),update(),saveOrUpdate()等方法 及調用查詢接口list,filter,iterate時,如Session緩存中還不存在相應的對象,Hibernate會把該對象加入到一級緩存中,當Session關閉的時候緩存也會消失。

Hibernate的一級緩存是Session所內置的,不能被卸載,也不能進行任何配置一級緩存採用的是key-value的Map方式來實現的,在緩存實體對象時,對象的主關鍵字ID是Map的key,實體對象就是對應的值。

Hibernate二級緩存:把獲得的所有數據對象根據ID放入到第二級緩存中。Hibernate二級緩存策略,是針對於ID查詢的緩存策略,刪除、更新、增加數據的時候,同時更新緩存。

進程和線程的區別:

進程:每個進程都有獨立的代碼和數據空間(進程上下文),進程間的切換會有較大的開銷,一個進程包含1–n個線程。

線程:同一類線程共享代碼和數據空間,每個線程有獨立的運行棧和程序計數器(PC),線程切換開銷小。

線程和進程一樣分為五個階段:創建、就緒、運行、阻塞、終止。

多進程是指作業系統能同時運行多個任務(程序)。

多線程是指在同一程序中有多個順序流在執行。

在java中要想實現多線程,有三種手段,一種是繼續Thread類,另外一種是實現Runable接口,還有就是實現Callable接口。

Switch能否用string做參數?

a.在 Java 7 之前, switch 只能支持byte,short,char,int 或者其對應的封裝類以及 Enum 類型。在Java 7中,String 支持被加上了。

Object有哪些公用方法?

a.方法equals測試的是兩個對象是否相等

b.方法clone進行對象拷貝

c.方法getClass返回和當前對象相關的Class對象

d.方法notify,notifyall,wait都是用來對給定對象進行線程同步的

Java的四種引用,強弱軟虛,以及用到的場景

a.利用軟引用和弱引用解決OOM問題:用一個HashMap來保存圖片的路徑和相應圖片對象關聯的軟引用之間的映射關係,在內存不足時,JVM會自動回收這些緩存圖片對象所佔用的空間,從而有效地避免了OOM的問題。

b.通過軟可及對象重獲方法實現Java對象的高速緩存:比如我們創建了一Employee的類,如果每次需要查詢一個僱員的信息。哪怕是幾秒中之前剛剛查詢過的,都要重新構建一個實例,這是需要消耗很多時間的。我們可以通過軟引用和 HashMap 的結合,先是保存引用方面:以軟引用的方式對一個Employee對象的實例進行引用並保存該引用到HashMap 上,key 為此僱員的 id,value為這個對象的軟引用,另一方面是取出引用,緩存中是否有該Employee實例的軟引用,如果有,從軟引用中取得。如果沒有軟引用,或者從軟引用中得到的實例是null,重新構建一個實例,並保存對這個新建實例的軟引用。

c.強引用:如果一個對象具有強引用,它就不會被垃圾回收器回收。即使當前內存空間不足,JVM也不會回收它,而是拋出 OutOfMemoryError 錯誤,使程序異常終止。如果想中斷強引用和某個對象之間的關聯,可以顯式地將引用賦值為null,這樣一來的話,JVM在合適的時間就會回收該對象。

d.軟引用:在使用軟引用時,如果內存的空間足夠,軟引用就能繼續被使用,而不會被垃圾回收器回收,只有在內存不足時,軟引用才會被垃圾回收器回收。

e.弱引用:具有弱引用的對象擁有的生命周期更短暫。因為當 JVM 進行垃圾回收,一旦發現弱引用對象,無論當前內存空間是否充足,都會將弱引用回收。不過由於垃圾回收器是一個優先級較低的線程,所以並不一定能迅速發現弱引用對象。

f.虛引用:顧名思義,就是形同虛設,如果一個對象僅持有虛引用,那麼它相當於沒有引用,在任何時候都可能被垃圾回收器回收。

Hashcode的作用,與 equal 有什麼區別?

a.同樣用於鑑定2個對象是否相等的,java集合中有 list 和 set 兩類,其中 set不允許元素重複實現,那個這個不允許重複實現的方法,如果用 equal 去比較的話,如果存在1000個元素,你 new 一個新的元素出來,需要去調用1000次 equal 去逐個和他們比較是否是同一個對象,這樣會大大降低效率。hashcode實際上是返回對象的存儲地址,如果這個位置上沒有元素,就把元素直接存儲在上面,如果這個位置上已經存在元素,這個時候才去調用equal方法與新元素進行比較,相同的話就不存了,散列到其他地址上。

Override和Overload的含義以及區別

a.Overload顧名思義是重新加載,它可以表現類的多態性,可以是函數裡面可以有相同的函數名但是參數名、返回值、類型不能相同;或者說可以改變參數、類型、返回值但是函數名字依然不變。

b.就是ride(重寫)的意思,在子類繼承父類的時候子類中可以定義某方法與其父類有相同的名稱和參數,當子類在調用這一函數時自動調用子類的方法,而父類相當於被覆蓋(重寫)了。

具體可前往C++中重載、重寫(覆蓋)的區別實例分析查看

抽象類和接口的區別

a.一個類只能繼承單個類,但是可以實現多個接口

b.抽象類中可以有構造方法,接口中不能有構造方法

c.抽象類中的所有方法並不一定要是抽象的,你可以選擇在抽象類中實現一些基本的方法。而接口要求所有的方法都必須是抽象的

d.抽象類中可以包含靜態方法,接口中不可以

e.抽象類中可以有普通成員變量,接口中不可以

解析XML的幾種方式的原理與特點:DOM、SAX、PULL

a.DOM:消耗內存:先把xml文檔都讀到內存中,然後再用DOM API來訪問樹形結構,並獲取數據。這個寫起來很簡單,但是很消耗內存。要是數據過大,手機不夠牛逼,可能手機直接死機

b.SAX:解析效率高,佔用內存少,基於事件驅動的:更加簡單地說就是對文檔進行順序掃描,當掃描到文檔(document)開始與結束、元素(element)開始與結束、文檔(document)結束等地方時通知事件處理函數,由事件處理函數做相應動作,然後繼續同樣的掃描,直至文檔結束。

c.PULL:與 SAX 類似,也是基於事件驅動,我們可以調用它的next()方法,來獲取下一個解析事件(就是開始文檔,結束文檔,開始標籤,結束標籤),當處於某個元素時可以調用XmlPullParser的getAttributte()方法來獲取屬性的值,也可調用它的nextText()獲取本節點的值。

wait()和sleep()的區別

sleep來自Thread類,和wait來自Object類

調用sleep()方法的過程中,線程不會釋放對象鎖。而 調用 wait 方法線程會釋放對象鎖

sleep睡眠後不出讓系統資源,wait讓出系統資源其他線程可以佔用CPU

sleep(milliseconds)需要指定一個睡眠時間,時間一到會自動喚醒

JAVA 中堆和棧的區別,說下java 的內存機制

a.基本數據類型比變量和對象的引用都是在棧分配的

b.堆內存用來存放由new創建的對象和數組

c.類變量(static修飾的變量),程序在一加載的時候就在堆中為類變量分配內存,堆中的內存地址存放在棧中

d.實例變量:當你使用java關鍵字new的時候,系統在堆中開闢並不一定是連續的空間分配給變量,是根據零散的堆內存地址,通過哈希算法換算為一長串數字以表徵這個變量在堆中的」物理位置」,實例變量的生命周期–當實例變量的引用丟失後,將被GC(垃圾回收器)列入可回收「名單」中,但並不是馬上就釋放堆中內存

e.局部變量: 由聲明在某方法,或某代碼段裡(比如for循環),執行到它的時候在棧中開闢內存,當局部變量一但脫離作用域,內存立即釋放

JAVA多態的實現原理

a.抽象的來講,多態的意思就是同一消息可以根據發送對象的不同而採用多種不同的行為方式。(發送消息就是函數調用)

b.實現的原理是動態綁定,程序調用的方法在運行期才動態綁定,追溯源碼可以發現,JVM 通過參數的自動轉型來找到合適的辦法。

相關焦點

  • 乾貨#Java常見面試問題匯總
    那麼,在JAVA如此盛行的時候,一般面試官都會考察我們哪些專業問題呢?筆者為計劃從事JAVA編程相關崗位的你們總結了一些面試官常問到的問題,希望給大家做個參考。Lock 是 java.util.concurrent.locks.lock 包下的,是 api層面的鎖。使用方法Synchronized 不需要用戶手動釋放鎖,代碼完成之後系統自動讓線程釋放鎖ReentrantLock 需要用戶手動釋放鎖,沒有手動釋放可能導致死鎖。
  • 簡單的面試題目,大跌眼鏡的結果(JAVA)
    所以越來越多的組織會採用電話面試的方式,進行初步篩選。題目難度一再降低,結果卻大跌眼鏡,HR都哭了。以下是一個簡單統計,樣本幾百人不等,能夠全部答上來的,不超過10%。哦,全錯的也有!快來看看我這b裝的分數高,還是你得的分數高,滿分10分!
  • 2年Java開發工作經驗面試總結
    3.前一家公司是傳統電信行業,加入項目組時,項目已經上線有段時間了,我們的任務就是有需求就開發,有bug就優化,其他時間就聊騷,各幹各的,工作一年多跟在養老一樣,用一句話說就是編程5分鐘,扯淡2小時,項目經驗嚴重不足,沒開發過很難的需求。分析:這一點是最傷的,公司招有經驗的就想看你都幹了些什麼牛批的東西,結果你告訴面試官我寫的需求都是垃圾。
  • 記一次Python後端開發面試的經歷
    記一次Python後端開發面試的經歷在拉勾上投了十幾個公司,大部分都被標記為不合適
  • 2年Java開發工作經驗,跳槽之後面試20餘家公司的總結
    3.前一家公司是傳統電信行業,加入項目組時,項目已經上線有段時間了,我們的任務就是有需求就開發,有bug就優化,其他時間就聊騷,各幹各的,工作一年多跟在養老一樣,用一句話說就是編程5分鐘,扯淡2小時,項目經驗嚴重不足,沒開發過很難的需求。分析:這一點是最傷的,公司招有經驗的就想看你都幹了些什麼牛批的東西,結果你告訴面試官我寫的需求都是垃圾。
  • 哪種程式語言適合後端開發,Java和PHP的區別在哪
    IT行業程序人員使用哪種程式語言一直都是大家討論的熱點,尤其是程式設計師們在面試的過程中還會被面試官們問到Java和PHP語言的區別是什麼? 如果從技術上看在web開發上,Java和PHP哪個更好呢? java已經是一門很成熟的語言,曾經看到一篇文章,講程式語言的進化,其中提到,java語言的進化樹太全了,使得其沒有發展的空間php是在web繁榮之後興起的語言,所以語言成熟度沒有java高,但PHP有一個最大的優點就是語法簡潔靈活。
  • 三年半 Java 後端鵝廠面試經歷
    面試職位:go後端開發工程師,接受從Java轉語言。都知道鵝廠是cpp的主戰場,而以cpp為背景的工程師大都對os,network這塊要求特別高,不像是Java這種偏重業務層的語言,之前面試Java的公司側重還是在數據結構、網絡、框架、資料庫和分布式。所以OS這塊吃的虧比較大。
  • 後端開發實踐:Spring Boot項目模板
    面試題內容聚合3. 設計模式內容聚合4. 排序算法內容聚合5. 多線程內容聚合在我的工作中,我從零開始搭建了不少軟體項目,其中包含了基礎代碼框架和持續集成基礎設施等,這些內容在敏捷開發中通常被稱為「第0個迭代」要做的事情。
  • 2021-Java後端工程師面試指南-(SpringBoot+SpringCloud)
    前言「文本已收錄至我的GitHub倉庫,歡迎Star:https://github.com/bin392328206/six-finger種一棵樹最好的時間是十年前,其次是現在」Tips面試指南系列,很多情況下不會去深挖細節,是小六六以被面試者的角色去回顧知識的一種方式,所以我默認大部分的東西,作為面試官的你,肯定是懂的
  • 初學編程,前端、後端開發哪個更有優勢?
    雖然嚴格來說,物聯網設備並沒有真正的前端,但他們都裝有固件,與移動App的前端類似,而這種固件可以用各種程式語言來開發。什麼是後端開發?後端開發又稱為「伺服器端」開發,主要涉及軟體系統後端的東西。JS開發框架源碼實現,(如:prototype、jQuery、Mootools,Ext, Dojo,underscore、YUI、Kissy),至少熟練一種(當然也不要去選一些用的人很少的框架,要明白大項目都是團隊做,不能自己搞一套);7.擁有良好的代碼編寫,設計文檔撰寫的經驗,熟練使用Git等版本控制工具;8.對常見的瀏覽器兼容問題有清晰的理解
  • Java後端面試經驗:了解8大核心競爭點,讓你輕鬆通過面試!
    最近面試java後端開發的感受:如果就以平時項目經驗來面試,通過估計很難——再論面試前的準備 在上周,我密集面試了若干位Java後端的候選人,工作經驗在3到5年間。
  • JNPF快速開發平臺-簡單快速高效開發java項目
    JNPF快速開發平臺 JNPF快速開發平臺採用前後端分離技術、採用B/S架構開發,形成一站式開發多端(APP+PC)使用。 使用JNPF開發平臺可以簡單、快速、高效的構建各種類型java項目。
  • web前端和後端的區別 web前端開發薪資
    Web後端:後端更多的是與資料庫進行交互以處理相應的業務邏輯。需要考慮的是如何實現功能、數據的存取、平臺的穩定性與性能等。 我們再來看看大公司對前後端人員招聘的要求,通過這個角度看看前端、後端的技術要求: Web前端: (1)精通HTML,能夠書寫語義合理,結構清晰,易維護的HTML結構。 (2)精通CSS,能夠還原視覺設計,併兼容業界承認的主流瀏覽器。
  • 後端Web開發:Node.js和Java
    在本文中,我們將重點關注Node.js作為後端開發環境的日益普及,以及Java開發人員在後端所做的事情。介紹對於今年的DZone資料庫指南,我們對來自整個IT行業的軟體專業人員進行了調查。我們收到了1,202條回復,完成率為64%。
  • 2021-Java後端工程師面試指南-(Elasticsearch)
    前言文本已收錄至我的GitHub倉庫,歡迎Star:https://github.com/bin392328206/six-finger種一棵樹最好的時間是十年前,其次是現在Tips面試指南系列,很多情況下不會去深挖細節,是小六六以被面試者的角色去回顧知識的一種方式,所以我默認大部分的東西
  • Java、JavaScript、PHP、Python是什麼?能開發什麼?
    java在手機領域發展也很廣泛,還記得當年的三星滑蓋手機裡全都是java開發的小遊戲,現在更是成為了安卓智能機的程式語言。應用:JavaScript是瀏覽器的腳本語言,javascript跟java沒有任何關係, 主要應用於Web應用開發,常用來為網頁添加各式各樣的動態功能,為用戶提供更流暢美觀的瀏覽效果,展現各種酷炫的畫面。
  • C、C ++、Java、PHP、Python分別用來開發什麼
    javajava常常跟「企業」聯繫在一起,因為具備一些很好的語言特性,以及豐富的框架,在企業應用中最被青睞,你總可以聽到關於J2EE,JSP,Hibernate之類的東西的討論。同時, java在手機領域也有一席之地,在普遍智能化之前,很多手機就是以支持java應用作為賣點的,而智慧型手機爆發之後,java手機主場變成了android,作為安卓的標準程式語言而存。
  • 50 個 Java 開發常見錯誤及規避技巧 (Part 1)
    在開發 Java 軟體時可能會遇到許多類型的錯誤,但大多數可以避免。
  • 作業幫後端一面、二面涼經
    作業幫一面:1.自我介紹2.項目3.java的面對對象特點並舉例說明4.問我LInkedList知道不?19.Spring Boot 需要獨立的容器運行嗎20.反問往期精彩推薦騰訊、阿里、滴滴後臺面試題匯總總結 — (含答案)面試:史上最全多線程面試題 !最新阿里內推Java後端面試題JVM難學?
  • 分享一下面試了幾個java程式設計師後的感受
    原文:https://www.cnblogs.com/JavaArchitect/p/9032323.html 本人最近幾年一直在做java後端方面的技術面試官,而在最近兩周,又密集了面試了一些java初級和高級開發的候選人,在面試過程中,我自認為比較慎重,遇到問題回答不好的候選人,我總會再三從不同方面提問