Java程序員找工做很難嗎?可能沒有get這些內容java
五分鐘閱讀下方文章mysql
常常面試一些候選人,整理了下我面試使用的題目,陸陸續續整理出來的題目不少,因此每次會抽一部分來問。答案會在後面的文章中逐漸發佈出來。linux
基礎題目nginx
- Java線程的狀態
- 進程和線程的區別,進程間如何通信,線程間如何通信
- HashMap的數據結構是什麼?如何實現的。和HashTable,ConcurrentHashMap的區別
- Cookie和Session的區別
- 索引有什麼用?如何建索引?
- ArrayList是如何實現的,ArrayList和LinkedList的區別?ArrayList如何實現擴容。
- equals方法實現
- 面向對象
- 線程狀態,BLOCKED和WAITING有什麼區別
- JVM如何加載字節碼文件
- JVM GC,GC算法。
- 什麼狀況會出現Full GC,什麼狀況會出現yong GC。
- JVM內存模型
- Java運行時數據區
- 事務的實現原理
技術深度程序員
- 有沒有看過JDK源碼,看過的類實現原理是什麼。
- HTTP協議
- TCP協議
- 一致性Hash算法
- JVM如何加載字節碼文件
- 類加載器如何卸載字節碼
- IO和NIO的區別,NIO優勢
- Java線程池的實現原理,keepAliveTime等參數的做用。
- HTTP鏈接池實現原理
- 數據庫鏈接池實現原理
- 數據庫的實現原理
技術框架面試
- 看過哪些開源框架的源碼
- 爲何要用Redis,Redis有哪些優缺點?Redis如何實現擴容?
- Netty是如何使用線程池的,爲何這麼使用
- 爲何要使用Spring,Spring的優缺點有哪些
- Spring的IOC容器初始化流程
- Spring的IOC容器實現原理,爲何能夠經過byName和ByType找到Bean
- Spring AOP實現原理
- 消息中間件是如何實現的,技術難點有哪些
系統架構redis
- 如何搭建一個高可用系統
- 哪些設計模式能夠增長系統的可擴展性
- 介紹設計模式,如模板模式,命令模式,策略模式,適配器模式、橋接模式、裝飾模式,觀察者模式,狀態模式,訪問者模式。
- 抽象能力,怎麼提升研發效率。
- 什麼是高內聚低耦合,請舉例子如何實現
- 什麼狀況用接口,什麼狀況用消息
- 若是AB兩個系統互相依賴,如何解除依賴
- 如何寫一篇設計文檔,目錄是什麼
- 什麼場景應該拆分系統,什麼場景應該合併系統
- 系統和模塊的區別,分別在什麼場景下使用
分佈式系統算法
- 分佈式事務,兩階段提交。
- 如何實現分佈式鎖
- 如何實現分佈式Session
- 如何保證消息的一致性
- 負載均衡
- 正向代理(客戶端代理)和反向代理(服務器端代理)
- CDN實現原理
- 怎麼提高系統的QPS和吞吐量
實戰能力sql
- 有沒有處理過線上問題?出現內存泄露,CPU利用率標高,應用無響應時如何處理的。
- 開發中有沒有遇到什麼技術問題?如何解決的
- 若是有幾十億的白名單,天天白天須要高併發查詢,晚上須要更新一次,如何設計這個功能。
- 新浪微博是如何實現把微博推給訂閱者
- Google是如何在一秒內把搜索結果返回給用戶的。
- 12306網站的訂票系統如何實現,如何保證不會票不被超賣。
- 如何實現一個秒殺系統,保證只有幾位用戶能買到某件商品。
軟能力mongodb
- 如何學習一項新技術,好比如何學習Java的,重點學習什麼
- 有關注哪些新的技術
- 工做任務很是多很是雜時如何處理
- 項目出現延遲如何處理
- 和同事的設計思路不同怎麼處理
- 如何保證開發質量
- 職業規劃是什麼?短時間,長期目標是什麼
- 團隊的規劃是什麼
- 能介紹下從工做到如今本身的成長在那裏
JAVA架構師的水準:
既然java架構師,首先你要是一個高級java攻城屍,熟練使用各類框架,並知道它們實現的原理。jvm虛擬機原理、調優,懂得jvm能讓你寫出性能更好的代碼;池技術,什麼對象池,鏈接池,線程池...:;java反射技術,寫框架必備的技術,可是有嚴重的性能問題,替代方案java字節碼技術;nio,沒什麼好說的,值得注意的是"直接內存"的特色,使用場景;java多線程同步異步;java各類集合對象的實現原理,瞭解這些可讓你在解決問題時選擇合適的數據結構,高效的解決問題,好比hashmap的實現原理,好多五年以上經驗的人都弄不清楚,還有爲什擴容時有性能問題?不弄清楚這些原理,就寫不出高效的代碼,還會認爲本身作的很對;總之一句話越基礎的東西越重要,不少人認爲本身會用它們寫代碼了,其實僅僅是知道如何調用api而已,離會用還差的遠。
熟練使用各類數據結構和算法,數組、哈希、鏈表、排序樹...,一句話要麼是時間換空間要麼是空間換時間,這裏展開能夠說一大堆,須要有必定的應用經驗,用於解決各類性能或業務上的問題;有時間再補充。
熟練使用linux操做系統,必備,沒什麼好說的 。
熟悉tcp協議,建立鏈接三次握手和斷開鏈接四次握手的整個過程,不瞭解的話,沒法對高併發網絡應用作優化; 熟悉http協議,尤爲是http頭,我發現好多工做五年以上的都弄不清session和cookie的生命週期以及它們之間的關聯。
系統集羣、負載均衡、反向代理、動靜分離,網站靜態化 。
分佈式存儲系統nfs,fastdfs,tfs,Hadoop瞭解他們的優缺點,適用場景 。
分佈式緩存技術memcached,redis,提升系統性能必備,一句話,把硬盤上的內容放到內存裏來提速,順便提個算法一致性hash 。
工具nginx必備技能超級好用,高性能,基本不會掛掉的服務器,功能多多,解決各類問題。
數據庫的設計能力,mysql必備,最基礎的數據庫工具,免費好用,對它基本的參數優化,慢查詢日誌分析,主從複製的配置,至少要成爲半個mysql dba。其餘nosql數據庫如mongodb。
還有隊列中間件。如消息推送,能夠先把消息寫入數據庫,推送放隊列服務器上,由推送服務器去隊列獲取處理,這樣就能夠將消息放數據庫和隊列裏後直接給用戶反饋,推送過程則由推送服務器和隊列服務器完成,好處異步處理、緩解服務器壓力,解藕系統。
以上純粹是經常使用的技術,還有不少本身慢慢去摸索吧;由於要知道的東西不少,因此要成爲一名合格的架構師,必需要有強大的自學能力,沒有人會手把手的教給你全部的東西
想成爲架構師不是懂了一大堆技術就能夠了,這些是解決問題的基礎、是工具,不懂這些怎麼去提解決方案呢?這是成爲架構師的必要條件。
架構師還要針對業務特色、系統的性能要求提出能解決問題成本最低的設計方案才合格,人家一個幾百人用戶的系統,訪問量不大,數據量小,你給人家上集羣、上分佈式存儲、上高端服務器,爲了架構而架構,這是最扯淡的,架構師的做用就是第一知足業務需求,第二最低的硬件網絡成本和技術維護成本。
架構師還要根據業務發展階段,提早預見發展到下一個階段系統架構的解決方案,而且設計當前架構時將架構的升級擴展考慮進去,作到易於升級;不然等系統瓶頸來了,出問題了再去出方案,或現有架構沒法擴展直接扔掉重作,或擴展麻煩問題一大堆,這會對企業形成損失。
程序員應該須要都有自知之明,會就是會,不會就是不會,互聯網發展迅速的時代,只能跟上時代的進步,纔不會被淘汰。
五分鐘的時間過去了
你會這些知識點,還怕很差找工做?
給你們推薦一套Java學習方向
獲取高清知識展現樹狀圖看下圖掃碼
須要面試資料看下圖
最好祝你們在Java的學習路上一路順風~