我是如何在秋招中拿到的offer的?

原創文章&經驗總結&從校招到A廠一路陽光一路滄桑

詳情請戳www.codercc.com

image

努力的意義,就是,在以后的日子里,放眼望去全是自己喜歡的人和事!

時間總是不知不覺的就溜走了,一晃,學生時代就真的要結束了。前天才吃完了師門的最后的聚餐,痛痛快快的喝了一頓酒。在酒中,對身邊的人感恩,也像是自己在對自己的學生時代告別。自己也特別喜歡校園這種簡單單純,讓人覺得很青春年輕的感覺,但是,是該開啟另一段人生旅程了。

從去年結束秋招,但現在忙完畢業論文答辯,這段時間應該算是“間隔月”。在完成秋招的時候,我對自己說,等有空余時間的時候,好好整理下。在準確秋招的時候,很多就是很直接去看面試題,像準備考試一樣,但很多感悟都是后知后覺的,但只要不是太晚就行。

自己特別喜歡并發問題,所以,我答應自己在間隔月好好理一下并發的基礎知識,算是給自己學生時代結束的禮物,我想,這一切就像是春日的陽光,溫暖而靜謐......最后,再多看看校園的梧桐。

關于這篇文章:(1)包含了并發的基礎知識,每個標題鏈接到一篇具體的文章;(2)包含了秋招面試的問題,弄懂了會讓你有所收獲(也祝大家都能找到心儀的工作:))(3)在閱讀過程中,如果有所幫助,麻煩點贊,算是對我的鼓勵,因為這所有的文章都是我親手打進去的,碼過字的應該都知道這其中所需要的堅持。

  1. 基礎知識

    1.1 并發編程的優缺點

    知識點:(1)為什么要用到并發?(優點);(2)并發編程的缺點;(3)易混淆的概念

    1.2 線程的狀態和基本操作

    知識點:(1)如何新建線程;(2)線程狀態的轉換;(3)線程的基本操作;(4)守護線程Daemon;

  2. 并發理論(JMM)

    java內存模型以及happens-before規則

    知識點:(1)JMM內存結構;(2)重排序;(3)happens-before規則

  1. 并發關鍵字

    3.1 讓你徹底理解Synchronized

    知識點:(1)如何使用synchronized;(2)monitor機制;(3)synchronized的happens-before關系;(4)synchronized的內存語義;(5)鎖優化;(6)鎖升級策略

    3.2 讓你徹底理解volatile

    知識點:(1)實現原理;(2)happens-before的關系推導;(3)內存語義;(4)內存語義的實現

    3.3 你以為你真的了解final嗎?

    知識點:(1)如何使用;(2)final的重排序規則;(3)final實現原理;(4)final引用不能從構造函數中“溢出”(this逃逸)

    3.4 三大性質總結:原子性,有序性,可見性

    知識點:(1)原子性:synchronized;(2)可見性:synchronized,volatile;(3)有序性:synchronized,volatile

  2. Lock體系

    4.1 初識Lock與AbstractQueuedSynchronizer(AQS)

    知識點:(1)Lock和synchronized的比較;(2)AQS設計意圖;(3)如何使用AQS實現自定義同步組件;(4)可重寫的方法;(5)AQS提供的模板方法;

    4.2 深入理解AbstractQueuedSynchronizer(AQS)

    知識點:(1)AQS同步隊列的數據結構;(2)獨占式鎖;(3)共享式鎖;

    4.3 再一次理解ReentrantLock

    知識點:(1)重入鎖的實現原理;(2)公平鎖的實現原理;(3)非公平鎖的實現原理;(4)公平鎖和非公平鎖的比較

    4.4 深入理解讀寫鎖ReentrantReadWriteLock

    知識點:(1)如何表示讀寫狀態;(2)WriteLock的獲取和釋放;(3)ReadLock的獲取和釋放;(4)鎖降級策略;(5)生成Condition等待隊列;(6)應用場景

    4.5 詳解Condition的await和signal等待/通知機制

    知識點:(1)與Object的wait/notify機制相比具有的特性;(2)與Object的wait/notify相對應的方法;(3)底層數據結構;(4)await實現原理;(5)signal/signalAll實現原理;(6)await和signal/signalAll的結合使用;

    4.6 LockSupport工具

    知識點:(1)主要功能;(2)與synchronized阻塞喚醒相比具有的特色;

  1. 并發容器

    5.1 并發容器之ConcurrentHashMap(JDK 1.8版本)

    知識點:(1)關鍵屬性;(2)重要內部類;(3)涉及到的CAS操作;(4)構造方法;(5)put執行流程;(6)get執行流程;(7)擴容機制;(8)用于統計size的方法的執行流程;(9)1.8版本的ConcurrentHashMap與之前版本的比較

    5.2 并發容器之CopyOnWriteArrayList

    知識點:(1)實現原理;(2)COW和ReentrantReadWriteLock的區別;(3)應用場景;(4)為什么具有弱一致性;(5)COW的缺點;

    5.3 并發容器之ConcurrentLinkedQueue

    知識點:(1)實現原理;(2)數據結構;(3)核心方法;(4)HOPS延遲更新的設計意圖

    5.4 并發容器之ThreadLocal

    知識點:(1)實現原理;(2)set方法原理;(3)get方法原理;(4)remove方法原理;(5)ThreadLocalMap

    一篇文章,從源碼深入詳解ThreadLocal內存泄漏問題

    知識點:(1)ThreadLocal內存泄漏原理;(2)ThreadLocal的最佳實踐;(3)應用場景

    5.5 并發容器之BlockingQueue

    知識點:(1)BlockingQueue的基本操作;(2)常用的BlockingQueue;

    并發容器之ArrayBlockingQueue和LinkedBlockingQueue實現原理詳解

  2. 線程池(Executor體系)

    6.1 線程池實現原理

    知識點:(1)為什么要用到線程池?(2)執行流程;(3)構造器各個參數的意義;(4)如何關閉線程池;(5)如何配置線程池;

    6.2 線程池之ScheduledThreadPoolExecutor

    知識點:(1)類結構;(2)常用方法;(3)ScheduledFutureTask;(3)DelayedWorkQueue;

    6.3 FutureTask基本操作總結

    知識點:(1)FutureTask的幾種狀態;(2)get方法;(3)cancel方法;(4)應用場景;(5)實現 Runnable接口

  3. 原子操作類

    7.1 Java中atomic包中的原子操作類總結

    知識點:(1)實現原理;(2)原子更新基本類型;(3)原子更新數組類型;(4)原子更新引用類型;(5)原子更新字段類型

  4. 并發工具

    8.1 大白話說java并發工具類-CountDownLatch,CyclicBarrier

    知識點:(1)倒計時器CountDownLatch;(2)循環柵欄CyclicBarrier;(3)CountDownLatch與CyclicBarrier的比較

    8.2 大白話說java并發工具類-Semaphore,Exchanger

    知識點:(1)資源訪問控制Semaphore;(2)數據交換Exchanger

  5. 并發實踐

    9.1 一篇文章,讓你徹底弄懂生產者--消費者問題

JAVA并發知識圖譜

可移動到新窗口,放大查看效果更好或者查看原圖

知識圖譜原圖鏈接,如果有用,可克隆給自己使用

JAVA并發知識圖譜.png
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容