此內容偏中高級,適合有三年經驗者。css
1. java中wait和sleep有什麼區別?多線程條件下如何保證數據安全?java
答:最大區別是等待時wait會釋放鎖(樂觀鎖),而sleep會一直持有鎖(悲觀鎖),wait一般用於線程時交,互,sleep一般被用於暫停執行。jquery
2. java中volatile和synchronized有什麼區別?linux
1.volatile本質是在告訴jvm當前變量在寄存器(工做內存)中的值是不肯定的,須要從主存中讀取;synchronized則是鎖定當前變量,只有當前線程能夠訪問該變量,其餘線程被阻塞住。 2.volatile僅能使用在變量級別;synchronized則可使用在變量、方法、和類級別的。 3.volatile僅能實現變量的修改可見性,並不能保證原子性;而synchronized則能夠保證變量的修改可見性和原子性。 4.volatile不會形成線程的阻塞;synchronized可能會形成線程的阻塞。 5.volatile標記的變量不會被編譯器優化;synchronized標記的變量能夠被編譯器優化。
3. 有了解java的原子類?實現原理是什麼?web
答:採用硬件提供原子操做指令實現的,即CAS。每次調用都會先判斷預期的值是否符合,才進行寫操做,保證數據安全。redis
4. spring主要使用了哪些?IOC實現原理是什麼?AOP實現原理是什麼?算法
答:spring主要功能有IOC,AOP,MVC等,IOC實現原理:先反射生成實例,而後調用時主動注入。AOP原理:主要使用java動態代理,spring
5. mybatis有了解嗎?它與hibernate有什麼區別?項目中,你會選哪一個?sql
答:二者都是輕量級ORM框架,hibernate實現功能比較多,經過HQL操做數據庫,比較簡單方便,但hibernate自動生成的sql相長,不利測試和查找緣由。複雜sql時,編寫比較困難,同時性能也會下降。mybatis是半自動化,手動編寫SQL語句,同時提供豐富的參數判斷功能。sql語句較清晰,能夠直接進行測試,性能也較好,操做起來很是簡單。同時hibernate容易產生n+1問題。hibernate學習成本較mybatis高。國內一些大公司基本上使用mybatis數據庫
6. 緩存框架有使用過哪些?memcache和redis有什麼區別?項目中,怎麼去選擇?
答:緩存有:ehcache,memcache和redis等
區別:
一、 Redis和Memcache都是將數據存放在內存中,都是內存數據庫。不過 memcache還可用於緩存其餘東西,例如圖片、視頻等等。
二、Redis不只僅支持簡單的k/v類型的數據,同時還提供包括string(字符串)、 list(鏈表)、set(集合)、zset(sorted set --有序集合)對象對應一個cores分數 默認經過分數排序 和hashs(哈希類型)等數據結構的 存儲。
三、虛擬內存--Redis當物理內存用完時,能夠將一些好久沒用到的value 交換到磁盤 (將跟更新的數據同步到硬盤中,修改操做追加到記錄文件中)
四、過時策略--memcache在set時就指定,例如set key1 0 0 8,即永不過時。Redis能夠通 過例如expire 設定,例如expire name 10
五、分佈式--設定memcache集羣,利用magent作一主多從;redis能夠作一主多從。都 能夠一主一從
六、存儲數據安全--memcache掛掉後,數據沒了;redis能夠按期保存到磁盤(持久化)
七、災難恢復--memcache掛掉後,數據不可恢復; redis數據丟失後可.以經過aof恢復
八、Redis支持數據的備份,即master-slave模式的數據備份。
項目使用選擇:
redis是單線程實現,若須要使用控制某些併發狀態時,可使用redis.項目中須要使用 複雜的list,set操做時,同時能夠對數據進行持久化。
當存儲數據較大時,如100k以上,那memcache性能較好,在多核上,memcache較 好
7. 說說數據庫性能優化有哪些方法?
答:使用explain進行優化,查看sql是否充分使用索引。避免使用in,用exist替代,字段值儘量使用更小的值,任何對列的操做都將致使表掃描,它包括數據庫函數、計算表達式等等,查詢時要儘量將操做移至等號右邊。使用鏈接查詢(join)代替子查詢。
在表的多列字段上創建一個索引,但只有在查詢這些字段的第一個字段時,索引纔會被使用。
8. HTTP請求方法get和post有什麼區別?
1:Post傳輸數據時,不須要在URL中顯示出來,而Get方法要在URL中顯示。
2:Post傳輸的數據量大,能夠達到2M,而Get方法因爲受到URL長度限制,只能 傳遞大約1024字節.
3:Post就是爲了將數據傳送到服務器段,Get就是爲了從服務器段取得數據.而Get 之因此也能傳送數據,只是用來設計告訴服務器,你到底須要什麼樣的數據.Post 的信息做爲http請求的內容,而Get是在Http頭部傳輸的。
9. linux命令熟悉?查看某個線程命令是什麼?查看整個機器負載命令?文件內容快速查找命令是什麼?
查看線程:ps -ef|grep tomcat
查看負載:top
文件內容查找:vi /aa test.txt 或者先打開文件,再查找: vi test.txt /aa
10. JVM內存模型是如何?垃圾回收機制有哪些?如何對JVM進行調優?
答:由棧和堆組成,棧是運行時單位,堆內存則分爲年輕代、年老代、持久代等,年輕代中的對象通過幾回的回收,仍然存在則被移到年老代;持久代主要是保存class,method,filed等對象。
sun回收機制:主要對年輕代和年老代中的存活對象進行回收,分爲如下:
年輕代串行(Serial Copying)、年輕代並行(ParNew)、年老代串行(SerialMSC),年老代並行(Parallel Mark Sweep),年老代併發(Concurrent Mark-Sweep GC,即CMS)等等,目前CMS回收算法使用最普遍。
JVM調優主要是對堆內容和回收算法進行配置,須要對jdk產生的回收日誌進行觀察,同時經過工具(Jconsole,jProfile,VisualVM)對堆內存不斷分析,這些優化是一個過程,須要不斷地進行觀察和維護。
11. 如銀行內部轉帳功能,如何保證數據一致性,即要麼同時成功,要麼同時失敗?高併發時,又如何保證性能和數據正確?
答:若是是單機內完成這些操做,那使用數據庫的事務,便可輕鬆實現。如果分佈式呢?
12. 有了解分佈式事務如何實現?
答:分佈式事務能夠採用分佈式鎖進行實現,目前zookeeper就提供此鎖;分佈式鎖須要犧牲必定性能去實現,若業務支付最終一致性,那此方法是最佳方案。如在京東下訂單,過一會纔會告訴你訂單審覈經過,而不是立刻響應訂單結果。
13. java抽象類和接口有什麼區別?項目中怎麼去使用它們?
相同點:
A. 二者都是抽象類,都不能實例化。
B. interface實現類及abstractc lass的子類都必需要實現已經聲明的抽象方法。
不一樣點:
A. interface須要實現,要用implements,而abstractclass須要繼承,要用extends。
B. 一個類能夠實現多個interface,但一個類只能繼承一個abstractclass。
C. interface強調特定功能的實現,而abstractclass強調所屬關係。
D. 儘管interface實現類及abstrctclass的子類都必需要實現相應的抽象方法,但實現的 形式不一樣。interface中的每個方法都是抽象方法,都只是聲明的 (declaration, 沒有方 法體),實現類必需要實現。而abstractclass的子類能夠有選擇地實現。
使用:
abstract:在既須要統一的接口,又須要實例變量或缺省的方法的狀況下,使用abstract;
interface:使用: 類與類以前須要特定的接口進行協調,而不在意其如何實現。 做爲能 夠實現特定功能的標識存在,也能夠是什麼接口方法都沒有的純粹標識。須要將一組類 視爲單一的類,而調用者只經過接口來與這組類發生聯繫。須要實現特定的多項功能, 而這些功能之間可能徹底沒有任何聯繫。
14. 對socket熟悉?TCP通信有幾回握手?有使用過哪些socket框架?
答:3次握手,客戶端-->服務端,服務端-->客戶端,客戶端-->服務端,當這些過程完成以後,才真正創建起通訊。java中比較有名的socket框架有:mina,netty,都是韓國小棒子寫的。
15. 瞭解java反射機制?反射生成類,能訪問私有變量?
答:即動態生成java的實例,能夠
16. RPC是什麼?有使用過哪些RPC框架?
答:即遠程進程調用,本地機器調用遠程的服務,在項目規模大到必定程度,須要使用RPC相關框架進行服務化部署。如:hessian 、webservice等
17. 熟悉js或css?jquery如何綁定頁面某元素的點擊事件?
答:$("#btn").click(function(){
})