Java基礎 mysql
● 集合類以及集合框架;HashMap與HashTable實現原理,線程安全性,hash衝突及處理算法;ConcurrentHashMap; c++
● 進程和線程的區別; 面試
● Java的併發、多線程、 線程模型; 算法
● 什麼是線程池,如何使用? 答:線程池就是事先將多個線程對象放到一個容器中,當使用的時候就不用new 線程而是直接去池中拿線程便可,節 sql
● 數據一致性如何保證;Synchronized關鍵字,類鎖,方法鎖,重入鎖; 設計模式
● Java中實現多態的機制是什麼; 安全
● 如何將一個Java對象序列化到文件裏; 服務器
● 說說你對Java反射的理解; 答:Java 中的反射首先是可以獲取到Java 中要反射類的字節碼, 獲取字節碼有三種方法, 網絡
● 同步的方法;多進程開發以及多進程應用場景; 數據結構
● 在Java中wait和seelp方法的不一樣;答:最大的不一樣是在等待時wait 會釋放鎖,而sleep 一直持有鎖。wait 一般被用於線程間交互,sleep 一般被用於暫停執行。
● synchronized 和volatile 關鍵字的做用;答:1)保證了不一樣線程對這個變量進行操做時的可見性,即一個線程修改了某個變量的值,這新值對其餘線程來講是當即可見的。2)禁止進行指令重排序。
● volatile 本質是在告訴jvm 當前變量在寄存器(工做內存)中的值是不肯定的,須要從主存中讀取;synchronized 則是鎖定當前變量,只有當前線程能夠訪問該變量,其餘線程被阻塞住。
1.volatile 僅能使用在變量級別;synchronized 則可使用在變量、方法、和類級別的
2.volatile 僅能實現變量的修改可見性,並不能保證原子性;synchronized 則能夠保證變量的修改可見性和原子性
3.volatile 不會形成線程的阻塞;synchronized 可能會形成線程的阻塞。
4.volatile 標記的變量不會被編譯器優化;synchronized 標記的變量能夠被編譯器優化
● 服務器只提供數據接收接口,在多線程或多進程條件下,如何保證數據的有序到達;
● ThreadLocal原理,實現及如何保證Local屬性;
● String StringBuilder StringBuffer對比;
● 你所知道的設計模式有哪些; 答:Java 中通常認爲有23 種設計模式,咱們不須要全部的都會,可是其中經常使用的幾種設計模式應該去掌握。下面列出了全部的設計模式。須要掌握的設計模式我單獨列出來了,固然能掌握的越多越好。
整體來講設計模式分爲三大類:
建立型模式,共五種:工廠方法模式、抽象工廠模式、單例模式、建造者模式、原型模式。
結構型模式,共七種:適配器模式、裝飾器模式、代理模式、外觀模式、橋接模式、組合模式、享元模式。
行爲型模式,共十一種:策略模式、模板方法模式、觀察者模式、迭代子模式、責任鏈模式、命令模式、備忘錄模式、狀態模式、訪問者模式、中介者模式、解釋器模式。
● Java如何調用c、c++語言;
● 接口與回調;回調的原理;寫一個回調demo;
● 泛型原理,舉例說明;解析與分派;
● 抽象類與接口的區別;應用場景;抽象類是否能夠沒有方法和屬性;
● 靜態屬性和靜態方法是否能夠被繼承?是否能夠被重寫?以及緣由?
● 修改對象A的equals方法的簽名,那麼使用HashMap存放這個對象實例的時候,會調用哪一個equals方法;
● 說說你對泛型的瞭解;
● Java的異常體系;
● 如何控制某個方法容許併發訪問線程的個數;
● 動態代理的區別,什麼場景使用;
最新部分
● 簡述synchronized?Object;Monitor機制;
● 簡述happen-before規則 ;
● JUC和Object ; Monitor機制區別是什麼 ; 簡述AQS原理 ;
● 簡述DCL失效緣由,解決方法 ;
● 簡述nio原理 ;
● jvm運行時數據區域有哪幾部分組成,各自做用 ;
● gc算法有哪些 ; gc收集器有哪些 ;
● 簡述class加載各階段過程 ; class ; loader有哪些模型 ;
● 簡述經常使用的JDK命令行工具 ;
● 簡述字節碼文件組成 ;
● 講講你日常是如何針對具體的SQL作優化 ;
● mysql的存儲引擎有哪些,區別 ;
● gc:內存模型;
● gc: 垃圾回收 ;
● 多線程:如何實現一個定時調度和循環調度的工具類。但提交任務處理不過來的時候,拒絕機制應該如何處理 ; 線程池默認有哪幾種拒絕機制 ;
● 多線程: 如何實現一個ThreadLocal ;
● 說說你瞭解的一個線程安全隊列 ;
● Atomic包的實現原理是什麼 ;
● CAS又是怎麼保證原子性的 ;
● string分析1000次循環subString用了多少內存 ;
數據結構與算法
● 堆和棧在內存中的區別是什麼(數據結構方面以及實際實現方面);
● 最快的排序算法是哪一個?給阿里2萬多名員工按年齡排序應該選擇哪一個算法?堆和樹的區別;寫出快排代碼;鏈表逆序代碼;
● 求1000之內的水仙花數以及40億之內的水仙花數;
● 子串包含問題(KMP 算法)寫代碼實現;
● 萬億級別的兩個URL文件A和B,如何求出A和B的差集C,(Bit映射->hash分組->多文件讀寫效率->磁盤尋址以及應用層面對尋址的優化)
● 蟻羣算法與蒙特卡洛算法;
● 寫出你所知道的排序算法及時空複雜度,穩定性;
● 百度POI中如何試下查找最近的商家功能(座標鏡像+R樹)。
其餘
● 死鎖的四個必要條件;
● 常見編碼方式;utf-8編碼中的中文佔幾個字節;int型幾個字節;
● 實現一個Json解析器(能夠經過正則提升速度);
● MVC MVP MVVM; 常見的設計模式;寫出觀察者模式的代碼;
● TCP的3次握手和四次揮手;TCP與UDP的區別;
● HTTP協議;HTTP1.0與2.0的區別;HTTP報文結構;
● HTTP與HTTPS的區別以及如何實現安全性;
● 都使用過哪些框架、平臺;
● 都使用過哪些自定義控件;
● 介紹你作過的哪些項目;
非技術問題
● 研究比較深刻的領域有哪些;
● 對業內信息的關注渠道有哪些;
● 最近都讀哪些書;
● 本身最擅長的技術點,最感興趣的技術領域和技術點;
● 項目中用了哪些開源庫,如何避免由於引入開源庫而致使的安全性和穩定性問題;
● 實習過程當中作了什麼,有什麼產出;
● 5枚硬幣,2正3反如何劃分爲兩堆而後經過翻轉讓兩堆中正面向上的硬幣和反面向上的硬幣個數相同;
● 時針走一圈,時針分針重合幾回;
● N * N的方格紙,裏面有多少個正方形;
● 如今下載速度很慢,試從網絡協議的角度分析緣由,並優化(網絡的5層均可以涉及)。
HR問題
● 您在前一家公司的離職緣由是什麼?
● 講一件你印象最深的一件事情;
● 介紹一個你影響最深的項目;
● 介紹你最熱愛最擅長的專業領域;
● 公司實習最大的收穫是什麼;
● 與上級意見不一致時,你將怎麼辦;
● 本身的優勢和缺點是什麼?並舉例說明?
● 你的學習方法是什麼樣的?實習過程當中如何學習?實習項目中遇到的最大困難是什麼以及如何解決的;
● 說一件最能證實你能力的事情;
● 針對你你申請的這個職位,你認爲你還欠缺什麼;
● 若是經過此次面試咱們單位錄用了你,但工做一段時間卻發現你根本不適合這個職位,你怎麼辦;
● 項目中遇到最大的困難是什麼?如何解決的;
● 你的職業規劃以及我的目標;將來發展路線及求職定位;
● 若是你在此次面試中沒有被錄用,你怎麼打算;
● 評價下本身,評價下本身的技術水平,我的代碼量如何;
● 經過哪些渠道瞭解的招聘信息,其餘同窗都投了哪些公司;
● 業餘都有哪些愛好;
● 你作過的哪件事最令本身感到驕傲;
● 假如你晚上要去送一個出國的同窗去機場,可單位臨時有事非你辦不可,你怎麼辦;
● 就你申請的這個職位,你認爲你還欠缺什麼;
● 當前的offer情況;若是BATH都給了offer該如何選;
● 你對一份工做更看重哪些方面?平臺,技術,氛圍,城市,money;
● 理想薪資範圍;杭州崗和北京崗選哪一個;
● 理想中的工做環境是什麼;
● 談談你對跳槽的見解;
● 說說你對行業、技術發展趨勢的見解;
● 實習過程當中周圍同事/同窗有哪些值得學習的地方;
● 家人對你的工做指望及本身的工做指望;
● 若是你的工做出現失誤,給本公司形成經濟損失,你認爲該怎麼辦;
● 若上司在公開會議上誤會你了,該如何解決;
● 是否能夠實習,能夠實習多久;
● 在五年的時間內,你的職業規劃;
● 你看中公司的什麼?或者公司的那些方面最吸引你。