阿里巴巴Java方向面試題匯總(含答案)2020最新
收集一些面試中經常會遇到的經典面試題以及自己面試過程中無法解決的問題,小偏整理了阿里巴巴Java方向面試題匯總(含答案)2020最新,謝謝您的認真閱讀。
阿里巴巴Java方向面試題匯總(含答案)2020最新
一、String, StringBuffer, StringBuilder的區(qū)別是什么?String為什么是不可變的?
1、String是字符串常量,StringBuffer和StringBuilder都是字符串變量。后兩者的字符內容可變,而前者創(chuàng)建后內容不可變。
2、String不可變是因為在JDK中String類被聲明為一個final類。
3、StringBuffer是線程安全的,而StringBuilder是非線程安全的。
補充說明:線程安全會帶來額外的系統(tǒng)開銷,所以StringBuilder的效率比StringBuffer高。如果對系統(tǒng)中的線程是否安全很掌握,可用StringBuffer,在線程不安全處加上關鍵字Synchronize。
二、Vector, ArrayList, LinkedList的區(qū)別是什么?
1、Vector、ArrayList都是以類似數組的形式存儲在內存中,LinkedList則以鏈表的形式進行存儲。
2、List中的元素有序、允許有重復的元素,Set中的元素無序、不允許有重復元素。
3、Vector線程同步,ArrayList、LinkedList線程不同步。
4、LinkedList適合指定位置插入、刪除操作,不適合查找;ArrayList、Vector適合查找,不適合指定位置的插入、刪除操作。
5、ArrayList在元素填滿容器時會自動擴充容器大小的約50%,而Vector則是100%,因此ArrayList更節(jié)省空間。
三、HashTable, HashMap, TreeMap的區(qū)別是什么?
1、HashTable線程同步,HashMap非線程同步。
2、HashTable不允許<鍵,值>有空值,HashMap允許<鍵,值>有空值。
3、HashTable使用Enumeration,HashMap使用Iterator。
4、HashTable中hash數組的默認大小是11,增加方式的old2+1,HashMap中hash數組的默認大小是16,增長方式一定是2的指數倍。
5、TreeMap能夠把它保存的記錄根據鍵排序,默認是按升序排序。
面小易說:以上三個問題所涉及的都是Java語言中的一些比較高級的數據結構,從字符串相關到容器再到哈希表和樹等數據結構,因此我們在學習Java語言的時候,也需要更加深入地去對比比較類似的數據結構的使用場景以及其優(yōu)缺點。
四、Tomcat,Apache,JBoss的區(qū)別?
1、Apache是HTTP服務器,Tomcat是Web服務器,JBoss是應用服務器。
2、Apache解析靜態(tài)的Html文件;Tomcat可解析jsp動態(tài)頁面、也可充當
容器。
面小易說:對于服務器而言,在面試中可能并不會過多涉及,相對而言,面小易認為像是Liunx、Tomcat這些背后的原理可能更受面試官的青睞。
五、GET,POST請求之間的區(qū)別?
基礎知識:HTTP的請求格式如下。
主要包含三個信息:1、請求的類型(GET或POST),2、要訪問的資源(如resimga.jif),3、HTTP版本(http/1.1)
區(qū)別:
1、Get是從服務器端獲取數據,Post則是向服務器端發(fā)送數據。
2、在客戶端,Get方式通過URL提交數據,在URL地址欄可以看到請求消息,該消息被編碼過;Post數據則是放在Html header內提交。
3、對于Get方式,服務器端用Request.QueryString獲取變量的值;對用Post方式,服務器端用Request.Form獲取提交的數據值。
4、Get方式提交的數據最多1024字節(jié),而Post則沒有限制。
5、Get方式提交的參數及參數值會在地址欄顯示,不安全,而Post不會,比較安全。
六、Session, Cookie的區(qū)別是什么?
1、Session由應用服務器維護的一個服務器端的存儲空間;Cookie是客戶端的存儲空間,由瀏覽器維護。
2、用戶可以通過瀏覽器設置決定是否保存Cookie,而不能決定是否保存Session,因為Session是由服務器端維護的。
3、Session中保存的是對象,Cookie中保存的是字符串。
4、Session和Cookie不能跨窗口使用,每打開一個瀏覽器系統(tǒng)會賦予一個SessionID,此時的SessionID不同,若要完成跨瀏覽器訪問數據,可以使用 Application。
5、Session、Cookie都有失效時間,過期后會自動刪除,減少系統(tǒng)開銷。
七、HTTP 報文包含內容
主要包含四部分:
1、request line
2、header line
3、blank line
4、request body
面小易說:上面的三個問題是網絡編程的基礎知識問題,作為Java工程師也需要掌握HTTP的知識,而如今HTTPS同樣也成為了標準,也需要大家進一步了解。此外,相對于大家在課本或者課堂中所學習的HTTP 1.0/1.1這些協(xié)議而言,很多公司已經邁入了HTTP 2.0時代,因此兩者之間的差別也需要我們進一步了解。
八、Servlet的生命周期
大致分為4部:Servlet類加載–>實例化–>服務–>銷毀
Tomcat中Servlet的時序圖如下所示:
1、Web Client向Servlet容器(Tomcat)發(fā)出HTTP請求。
2、Servlet容器接收Client端的請求。
3、Servlet容器創(chuàng)建一個HttpRequest對象,將Client的請求信息封裝到這個對象中。
4、Servlet創(chuàng)建一個HttpResponse對象。
5、Servlet調用HttpServlet對象的service方法,把HttpRequest對象和HttpResponse對象作為參數傳遞給HttpServlet對象中。
6、HttpServlet調用HttpRequest對象的方法,獲取Http請求,并進行相應處理。
7、處理完成HttpServlet調用HttpResponse對象的方法,返回響應數據。
8、Servlet容器把HttpServlet的響應結果傳回客戶端。
其中的3個方法說明了Servlet的生命周期:
1、init():負責初始化Servlet對象。
2、service():負責響應客戶端請求。
3、destroy():當Servlet對象推出時,負責釋放占用資源。
九、Statement與PreparedStatement的區(qū)別,什么是SQL注入,如何防止SQL注入?
1、PreparedStatement支持動態(tài)設置參數,Statement不支持。
2、PreparedStatement可避免如類似 單引號 的編碼麻煩,Statement不可以。
3、PreparedStatement支持預編譯,Statement不支持。
4、在SQL語句出錯時PreparedStatement不易檢查,而Statement則更便于查錯。
5、PreparedStatement可防止SQL助于,更加安全,而Statement不行。
補充說明-什么是SQL注入以及應對策略: 通過SQL語句的拼接達到無參數查詢數據庫數據目的的方法。如將要執(zhí)行的SQL語句為 select from table where name = “+appName+”,利用appName參數值的輸入,來生成惡意的SQL語句,如將[‘or’1’=‘1’] 傳入可在數據庫中執(zhí)行。因此可以采用PrepareStatement來避免SQL注入,在服務器端接收參數數據后,進行驗證,此時PrepareStatement會自動檢測,而Statement不行,需要手工檢測。
十、sendRedirect, foward區(qū)別
1、foward是服務器端控制頁面轉向,在客戶端的瀏覽器地址中不會顯示轉向后的地址;sendRedirect則是完全的跳轉,瀏覽器中會顯示跳轉的地址并重新發(fā)送請求鏈接。原理:forward是服務器請求資源,服務器直接訪問目標地址的URL,把那個URL的響應內容讀取過來,然后再將這些內容返回給瀏覽器,瀏覽器根本不知道服務器發(fā)送的這些內容是從哪來的,所以地址欄還是原來的地址。
2、redirect是服務器端根據邏輯,發(fā)送一個狀態(tài)碼,告訴瀏覽器重新去請求的那個地址,瀏覽器會用剛才的所有參數重新發(fā)送新的請求。
面小易說:以上的三個問題在之前網絡相關的知識上更進一步,上升到了Java網絡編程的相關知識,這部分意在考察面試者對于Java網絡編程相關知識的掌握程度。
十一、談談Hibernate的理解,一級和二級緩存的作用,在項目中Hibernate都是怎么使用緩存的?
Hibernate是一個開發(fā)的對象關系映射框架(ORM)。它對JDBC進行了非常對象封裝,Hibernate允許程序員采用面向對象的方式來操作關系數據庫。
Hibernate的優(yōu)點:
1、程序更加面向對象
2、提高了生產率
3、方便移植
4、無入侵性
Hibernate的缺點:
1、效率比JDBC略差
2、不適合批量操作
3、只能配置一種關聯(lián)關系
Hibernate有四種查詢方式:
1、get、load方法,根據ID號查詢對象。
2、Hibernate Query Language, HQL
3、標準查詢語言
4、通過SQL查詢
Hibernate工作原理:
1、配置Hibernate對象關系映射文件、啟動服務器
2、服務器通過實例化Configuration對象,讀取hibernate.cfg.xml文件的配置內容,并根據相關的需求建好表以及表之間的映射關系。
3、通過實例化的Configuration對象建立SessionFactory實例,通過SessionFactory實例創(chuàng)建Session對象。
4、通過Session對象完成數據庫的增刪改查操作。
Hibernate中的狀態(tài)轉移:
臨時狀態(tài)(Transient)
1、不處于Session緩存中
2、數據庫中沒有對象記錄
補充說明-Java是如何進入臨時狀態(tài)的:1、通過new語句創(chuàng)建一個對象時。2、剛調用Session的delete()方法時,從Session緩存中刪除一個對象時。
持久化狀態(tài)(Persisted)
1、處于Session緩存中
2、持久化對象數據庫中沒有對象記錄
3、Session在特定的時刻會保存兩者同步
補充說明-Java如何進入持久化狀態(tài):1、Session的save()方法。2、Session的load().get()方法返回的對象。3、Session的find()方法返回的list集合中存放的對象。4、Session的update().save()方法。
流離狀態(tài)(Detached)
1、不再位于Session緩存中
2、游離對象由持久化狀態(tài)轉變而來,數據庫中還沒有相應記錄。
補充說明-Java如何進入流離狀態(tài):1、Session的close()。2、 Session的evict()方法,從緩存中刪除一個對象。
具體如下圖所示:
Hibernate中的緩存主要有Session緩存(一級緩存)和SessionFactory緩存(二級緩存,一般由第三方提供)。
十二、談談Hibernate與iBatis的區(qū)別,哪個性能會更高一些
1、Hibernate偏向于對象的操作達到數據庫相關操作的目的;而iBatis更偏向于SQL語句的優(yōu)化。
2、Hibernate的使用的查詢語句是自己的HQL,而iBatis則是標準的SQL語句。
3、Hibernate相對復雜,不易學習;iBatis類似SQL語句,簡單易學。
性能方面:
1、如果系統(tǒng)數據處理量巨大,性能要求極為苛刻時,往往需要人工編寫高性能的SQL語句或存錯過程,此時iBatis具有更好的可控性,因此性能優(yōu)于Hibernate。
2、同樣的需求下,由于Hibernate可以自動生成HQL語句,而iBatis需要手動寫SQL語句,此時采用Hibernate的效率高于iBatis。
十三、對Spring的理解,項目中都用什么?怎么用的?對IOC、和AOP的理解及實現原理。
Spring是一個開源框架,處于MVC模式中的控制層,它能應對需求快速的變化,其主要原因它有一種面向切面編程(AOP)的優(yōu)勢,其次它提升了系統(tǒng)性能,因為通過依賴倒置機制(IOC),系統(tǒng)中用到的對象不是在系統(tǒng)加載時就全部實例化,而是在調用到這個類時才會實例化該類的對象,從而提升了系統(tǒng)性能。這兩個優(yōu)秀的性能使得Spring受到許多J2EE公司的青睞,如阿里中使用最多的也是Spring相關技術。
Spring的優(yōu)點:
1、降低了組件之間的耦合性,實現了軟件各層之間的解耦。
2、可以使用容易提供的眾多服務,如事務管理,消息服務,日志記錄等。
3、容器提供了AOP技術,利用它很容易實現如權限攔截、運行期監(jiān)控等功能。
Spring中AOP技術是設計模式中的動態(tài)代理模式。只需實現jdk提供的動態(tài)代理接口InvocationHandler,所有被代理對象的方法都由InvocationHandler接管實際的處理任務。面向切面編程中還要理解切入點、切面、通知、織入等概念。
Spring中IOC則利用了Java強大的反射機制來實現。所謂依賴注入即組件之間的依賴關系由容器在運行期決定。其中依賴注入的方法有兩種,通過構造函數注入,通過set方法進行注入。
十四、描述Struts的工作流程
1、在web應用啟動時,加載并初始化ActionServlet,ActionServlet從struts-config.xml文件中讀取配置信息,將它們存放到各個配置對象中。
2、當ActionServlet接收到一個客戶請求時,首先檢索和用戶請求相匹配的ActionMapping實例,如果不存在,就返回用戶請求路徑無效信息。
3、如果ActionForm實例不存在,就創(chuàng)建一個ActionForm對象,把客戶提交的表單數據保存到ActionForm對象中。
4、根據配置信息決定是否需要驗證表單,如果需要,就調用ActionForm的validate()方法,如果ActionForm的validate()方法返回null或返回一個不包含ActionMessage的ActionErrors對象,就表示表單驗證成功。
5、ActionServlet根據ActionMapping實例包含的映射信息決定請求轉發(fā)給哪個Action,如果相應的Action實例不存在,就先創(chuàng)建一個實例,然后調用Action的execute()方法。
面小易說:以上部分的相關問題考察面試者在實際軟件開發(fā)中所使用的Java語言相關框架以及對于框架原理的了解程度,這一部分我們需要注意一些常見的框架,不僅需要知道它們是干什么的,還需要知道它們背后的原理,常會問到的框架有Spring Boot/Spring Cloud全家桶、Hibernate、MyBaits、Netty、Kafka等,最重要的還有阿里巴巴開源的Apache Dubbo框架。
十五、關于Java內存模型,一個對象(兩個屬性,四個方法)實例化100次,現在內存中的存儲狀態(tài),幾個對象,幾個屬性,幾個方法。由于Java中new出來的對象都是放在堆中,所以如果要實例化100次,將在堆中產生100個對象,一般對象與其中的屬性、方法都屬于一個整體,但如果 屬性和方法是靜態(tài)的,就是用static關鍵字聲明的,那么屬于類的屬性和方法永遠只在內存中存在一份。
十六、反射講一講,主要是概念,都在哪需要反射機制,反射的性能,如何優(yōu)化?
反射機制的定義:
是在運行狀態(tài)中,對于任意的一個類,都能夠知道這個類的所有屬性和方法,對任意一個對象都能夠通過反射機制調用一個類的任意方法,這種動態(tài)獲取類信息及動態(tài)調用類對象方法的功能稱為java的反射機制。
反射的作用:
1、動態(tài)地創(chuàng)建類的實例,將類綁定到現有的對象中,或從現有的對象中獲取類型。
2、應用程序需要在運行時從某個特定的程序集中載入一個特定的類。
十七、線程同步,并發(fā)操作怎么控制?
Java中可在方法名前加關鍵字syschronized來處理當有多個線程同時訪問共享資源時候的問題。syschronized相當于一把鎖,當有申請者申請該資源時,如果該資源沒有被占用,那么將資源交付給這個申請者使用,在此期間,其他申請者只能申請而不能使用該資源,當該資源被使用完成后將釋放該資源上的鎖,其他申請者可申請使用。并發(fā)控制主要是為了多線程操作時帶來的資源讀寫問題。如果不加以空間可能會出現死鎖,讀臟數據、不可重復讀、丟失更新等異常。
并發(fā)操作可以通過加鎖的方式進行控制,鎖又可分為樂觀鎖和悲觀鎖。
悲觀鎖:
悲觀鎖并發(fā)模式假定系統(tǒng)中存在足夠多的數據修改操作,以致于任何確定的讀操作都可能會受到由個別的用戶所制造的數據修改的影響。也就是說悲觀鎖假定沖突總會發(fā)生,通過獨占正在被讀取的數據來避免沖突。但是獨占數據會導致其他進程無法修改該數據,進而產生阻塞,讀數據和寫數據會相互阻塞。
樂觀鎖:
樂觀鎖假定系統(tǒng)的數據修改只會產生非常少的沖突,也就是說任何進程都不大可能修改別的進程正在訪問的數據。樂觀并發(fā)模式下,讀數據和寫數據之間不會發(fā)生沖突,只有寫數據與寫數據之間會發(fā)生沖突。即讀數據不會產生阻塞,只有寫數據才會產生阻塞。
附面試技巧
seo面試84個問題及答案:
1. 你最喜歡SEO的哪一部分? 站內優(yōu)化
2. 你覺得SEO中最困難的是什么? 把客戶培養(yǎng)為忠實客戶(轉化率)
3. 你在SEO中犯過的最大錯誤是什么? 沒有自己的站,以前刷過公司的站
4. 你在SEO中獲得的最大成功是什么? 知道如何去分析觀察SE.
5. 你有自己的網站嗎?網址是什么?你做這些網站的目的是什么?他們取得了怎樣的成績? NO
6. 你之前做SEO的網站是做什么生意的? NO
7. 你覺得自己作為一個SEO最有競爭力的是哪一方面? SEO知識相當扎實,SEO策略還可以^_^
8. 你覺得MATT CUTTS(GOOGLE工程師)怎么樣 我不是很懂英文
考察SEO學習能力
9. 你最喜歡的SEO網站/博客是什么?為什么? ZAC,SEO研究中心,BSG等.
10.你在SEO界最尊敬的人是誰?為什么? ZAC,權威和啟蒙老師
11.你在SEO界最不尊敬的人是誰?為什么? 目前還沒有,真沒有.
12.你每天在哪個網站學習新知識 ? moonseo.net BSG
統(tǒng)計
13.你用過哪些流量統(tǒng)計工具? 百度統(tǒng)計,CNZZ
14.通過統(tǒng)計工具設定目標轉換的流程是什么? 本人做信息站所以目的是留下用戶,所以....大家都懂撒.我在扯蛋,這里不是很懂.
15.解釋一下這個流程(設定目標轉換)的高端部分,然后說說為什么要這么用? 站內布局^_^
16.如果要你來制定一個當前的統(tǒng)計工具沒有的或者不完善的新功能,你會怎么做? EXCEL記錄一些重要數據,分析對比.