注明:這是一個勵志老哥給我分享的個人經歷,發本文的目的是為了讓大家可以參考他的學習經歷,提高自己的能力!當然人外有人天外有天,大神也別打我!再次說明,我只是為了能夠幫助迷茫的兄弟們!接下來以他的第一視角為大家講述他的經歷,

可能故事有點長,大家是想聽故事還是直接聽我講我學了什么,怎么學習的,
好吧,進入實驗室的程序我就不細說了,最后選了兩個人,一個就是我!!
進去的第一個專案是做一個javase的桌面專案,我和同伴負責的是寫界面,
當時就覺得有機會寫真正專案就已經很開心了,根本不考慮寫什么,就算寫寫界面我都很高興,
在寫界面的時候,第一次用了HashMap,是師兄教我們用的,,當時覺得好厲害,對師兄一直處于崇拜當中,(對!當時就是這么菜,HashMap都不知道)
現在回頭看看自己的代碼,全是面向程序的,怪不得師兄們不叫我寫其他的,真的是菜的不行,
好吧,java初級就算完成了,當時這個專案也是全部寫的界面,所以完全就沒有鍛煉到什么(實際上還是有的,比如說SVn),這個時候我處于的階段就是,java一知半解,mysql陳述句都要一邊查一邊寫才能寫出來,
這個時候我的時間就比較閑了,在詢問過師兄之后我決定利用書籍來提高自己,這段時間我看的書有(大概一個月),《java核心技術,卷一》,《java編程思想》(目前仍然看不懂),jsp,servlet在自學當中,
最要是看《java核心技術》,當時我只看得懂這個,然后把上面的代碼大概的敲了一遍,后來我又用servlet開發了自己學校的威信平臺,都是很簡單的功能,
我先列一下我看過的書單:
- 《java核心技術,卷一》,
- 《java設計模式》,
- 《java編程思想》,
- 《深入理解jvm原理》,
- 《編程之美》,
- 《劍指offer》,
- 《深入分析javaweb,技術內幕》,
- 《深入分析spring技術內幕》,
- 《分布式Java應用:基礎與實踐》,
- 《hadoop技術內幕》,
但你們不知道學什么的時候就看看這張圖,我覺得很有幫助,接下來說說我的學習方法,
樓主的觀點是:如果你想提高自己的水平,一定要和優秀的人交流,學習他們的思維方式和處事能力,感知他們的氣場,看看比你優秀的人在干什么!!
如果你發現比你優秀的人還比你帥還比你努力,那你就真的是個loser
當然樓上說的是做人方面,我現在說說技術吧,
基礎:這是非常非常非常非常重要的,只要基礎好了,框架什么的你自己都能寫,還學什么框架(學框架更加快),那什么屬于基礎呢?我覺得有以下東西,資料結構、計算機網路、資料庫、作業系統,這是計算機基礎,在java的話,我覺得應該是,IO,NIO,并發(包括concurrent包下的),集合框架(理解原理,多看看原始碼),反射,面對物件的思想,OOP,OOA,OOD,JVM,JMM(這兩個雖然實戰經驗很少,當時一定要去學習了解一下你就知道什么時候用volatile什么時候用sync),
提高:在基礎上面如何提高自己呢?我們有基礎之后,我覺得需要學習設計模式,深入的學習資料庫(包括,索引原理,ACID,事務隔離機制,觸發器,存盤程序等等,資料庫的鎖機制,行鎖,表鎖,悲觀,樂觀,),在這個階段要學會看看原始碼,把IOC,AOP的原理弄清楚,Spring是怎么找到bean,怎么加載,怎么決議等等,,當你遇到此類問題,你可以馬上就找到問題在哪里,這就是看原始碼的好處,Aop也不能只是了解動態代理的原理,還要知道什么是aspect,pointcut等等,為什么AOP聯盟要定義這些介面…這個時候你就要知道什么是解耦合,什么是高類聚,怎樣讓代碼變得可重用行和擴展性更高,設計模式帶給你的好處將是質的變化,
深入:其實到這里都是看自己了吧,了解什么是SOA,OSGI,什么是分布式(分布式資料庫,分布式檔案系統),負載均衡(lvs,Ngnix等),了解云計算,了解實時計算,知道spark,hadoop,storm,什么是虛擬化技術,這方面我也只是入門,不敢多寫!
平常怎樣學習:
1、給自己定下目標,
2、多看看好的博客,
3、多了解新的技術(就算你不是學前端的你也要知道前端貌似有個AngularJS,擴寬眼界)
4、多寫代碼、
5、少去java吧水
6、堅持!!!!!!!!!!!!!!!!!!,
送大家一句話:越努力,越幸運!
收集一些阿里巴巴招聘的題目(都是最近周圍同學的面試經驗)
java后臺方向NO1:
- 1.Arraylist和linkedlist的區別及原理
- 2.常用的IO有哪些,io框架用的什么設計模式
- 3.vector和arraylist有什么區別
- 4.怎樣創建一個執行緒,用什么啟動
- 5,4個視窗,20個人怎樣保證并發,說說ConcurrentHashmap原理
- 7,兩個陣列一個100長度,一個101長度,前一個是后一個的子集,怎樣找出多出的一個數
- 8,了解NIO嗎?說說優點
- 9,JSP 9大內置物件
- 10.看過哪些書籍,說說作者和書的名字
- 11.分布式節點內部通信機制
- 12,說說你的框架,怎樣理解MVC的
- 13.知道網路編程嗎?說說分布式,
- 14,說說你的網站架構,SOA管理方式,什么是webservice
- 15,什么是RPC框架,有什么優點
- 16,你平常是怎么學習的
- 17.團隊是如何管理的,你處于一個什么位置
- 18,怎樣協調團隊矛盾
- 20,介紹你的專案,分布式資料庫怎么分表,用的什么中間件
java后臺方向NO2:
- 3.對中間件的了解
- 4.平時從哪里學習這些技術
- 5.遇到技術問題如何解決,舉nginx負載的例子,,
- 6.怎么讀原始碼,說了一下nginx記憶體池的實作
- 1.mysql連接池作用,實作
- 3.怎么預防死鎖,出現死鎖怎么解決
- 4.常見設計模式和其運用
- 1.你是怎么設計資料庫的
- 2.資料庫索引有哪些 索引基于哪些型別實作
- 3.你是怎么根據索引去資料庫優化
- 4.GC root
- 5.事務
- 6.ConcurrentHashMap HashMap(這里講了下ConcurrentHashMap原始碼,及JAVA中鎖的實作原理基于AQS,AQS原理,基于CAS實作)
- 7.對了,還有JMM volatile原理
- 1.JTA實作原理(onepc two pc three pc) :二階段提交出現的問題,就說了一下加入observe,后面討論了下二階段提交的腦列問題
- 2.Spring (這里講了一下自己的IOC) 分析了一下AOP
- 3.討論了支付寶搶紅包的采取了哪些優化,事務基于幾階段提交…
- 2.負載均衡 LVS與ngnix區別
- 3.其他的都是一些學習方法方面的,,
- 1.在專案中用過哪些設計模式,解決了什么問題,優缺點,
- 2.表設計 三范式,反范式
- 3.事務 銀行轉賬例子,, a和b不在同一個庫里面的事務設計,mysql怎么做,自己寫代碼怎么實作
- 4.Nginx 負載 介紹反向代理的概念 負載常見演算法
- 5.負載多服務器之間如何通信,
- 6.高并發問題 雙十一,你覺得哪個會先掛,,我說的是mysql,怎么解決,
- 1.計算機網路七層模型,TCP三次握手
- 2.說說常見的TCP應用
- 3.說說常見的linux命令
- 4,JVM的垃圾回收,volatile 機制,記憶體模型
- 5.string,stringbuffer,stringbuilder的區別,ArrayList,linkedList 的差別 查找 洗掉的時間復雜度,
- 6.Spring AOP,IOC
- 7.HashMap原始碼,執行緒池框架原始碼
- 8.常見的設計模式并說明用處
- IO模型有哪些?
- 行程執行緒的區別
- 不同作業系統實作行程怎么樣
- gc演算法,回收器有哪些
- ACID,事務隔離機制
- syn在方法上和代碼塊有什么不同
- memcached和其他nosql不區別
- 解釋mvc
- threadlocal解釋
- volatile的作用
- 堆和堆疊的區別和聯系
- tcp和udp的不同之處
- tcp如何保證可靠的
- 陣列和鏈表的區別
- 排序演算法應用場景
- lucene全文檢索原理
- 瀏覽器輸入http://www.baidu.com,整個流程
- 分布式快取,一致性HasH演算法,memcached記憶體結構
- tcp三次握手
- tcp滑動視窗解釋
- SSO單點登錄
- 資料庫分表,磁區
- /O:將物件轉換為檔案實作什么介面
- 反射:反射是哪一個類 有些什么方法 通過反射獲取方法時,能獲取private的方法嗎?protected?
- servlet:流程 服務器和session的聯系 cookie和session的區別
- springmvc:流程 處理請求是哪一個類,有些什么方法,它實作了什么介面
- spring:兩個特性解釋 哪些地方用到aop 宣告式事務管理的步驟(每一步相關的類)
- 資料庫:分頁的sql 還有個什么sql忘了 left join和right join的區別
- 集合框架:collection下面有什么 arrayList和linkedList區別 結合hashmap原始碼分析hashmap
- jvm原理 classloader 堆疊區別 堆疊原理
- 垃圾回識訓制作業原理 當物件不再呼叫,就進行回收嗎還是怎樣 System.gc執行后,直接進行回收嗎還是怎樣
- tcp/ip區別 一個方法要同步怎么辦 怎樣實作執行緒
- 抽象類和介面的區別(這里問得很細) 抽象類和普通類的優缺點
- memcached原理 流程 它的分布式演算法 快取策略
- 還有演算法 快速排序
最后歷年來阿里面試題目相關知識點分享:
分布式
- 一、大型網站系統的特點
- 二、大型網站架構演化發展歷程
- 三、拆分 VS 集群
- 四、微服務 VS SOA
- 五、前后端完全分離與Rest規范
- 六、CAP三進二和Base定理

中間件
- 一、快取
- 二、訊息佇列
- 三、搜索引擎

大資料與高并發
- 一、秒殺架構設計
- 二、資料庫架構發展歷程
- 三、MySQL的擴展性瓶頸
- 四、為什么要使用NOSQL NOT ONLY SQL
- 五、傳統RDBMS VS NOS QL
- 六、NOSQL資料庫的型別
- 七、阿里巴巴中文站商品資訊如何存放
- 八、資料的水平拆分和垂直拆分
- 九、分布式事務
- 十、BitMap
- 十一、Bloom Filter
- 十二、常見的限流演算法
- 十三、負載均衡
- 十四、一致性Hash演算法

資料庫
- 一、資料庫范式
- 二、資料庫開發規范
- 三、資料庫索引
- 四、MyISAM vs InnoDB
- 五、并發事務帶來的問題
- 六、事務隔離級別及鎖的實作機制
- 七、MVCC(多版本并發控制)
- 八、間隙鎖與幻讀

設計模式與實踐
- 一、OOP五大原則SOLID
- 二、設計模式
- 三、代理模式
- 四、面向切面編程(AOP)
- 五、工廠模式
- 六、控制反轉IOC
- 七、觀察者模式
- 八、Zookeeper

資料結構與演算法
- 一、樹
- 二、BST樹
- 三、BST樹
- 四、AVL樹
- 五、紅黑樹
- 六、B-樹
- 七、B+樹
- 八、字典樹
- 九、跳表
- 十、HashMap
- 十一、ConcurrentHashM ap
- 十二、ConcurrentLinked Queue
- 十三、Topk問題十四、資源池思想
- 十五、JVM記憶體管理演算法
- 十六、容器虛擬化技術,Doocker思想
- 十七、持續集成、持續發布,jenkins

面試題舉例
- 一、設計一個分布式環境下全域唯一的發號器
- 二、設計一個帶有過期時間的LRU快取
- 三、設計一個分布式鎖
- 四、設計一個分布式環境下的統一配置中心
- 五、如何準備HR面試

拿這份資料應付大多數企業面試肯定是綽綽有余的,有興趣可以點擊下方名片免費領取完整版,如果決定有用的話可以點贊評論轉發三連一下,謝謝大家~
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/336236.html
標籤:java
下一篇:Linux全面決議講解

