自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

3年工作經(jīng)驗(yàn)的程序員應(yīng)該具備的技能

開(kāi)發(fā)
每個(gè)程序員、或者說(shuō)每個(gè)工作者都應(yīng)該有自己的職業(yè)規(guī)劃,如果你不是富二代,不是官二代,也沒(méi)有職業(yè)規(guī)劃,希望你可以思考一下自己的將來(lái)。今天小編給大家分享的是一篇來(lái)自阿里Java工程師對(duì)3年工作經(jīng)驗(yàn)程序員的職業(yè)建議,希望對(duì)你有啟發(fā)。

[[213050]]

每個(gè)程序員、或者說(shuō)每個(gè)工作者都應(yīng)該有自己的職業(yè)規(guī)劃,如果你不是富二代,不是官二代,也沒(méi)有職業(yè)規(guī)劃,希望你可以思考一下自己的將來(lái)。今天小編給大家分享的是一篇來(lái)自阿里Java工程師對(duì)3年工作經(jīng)驗(yàn)程序員的職業(yè)建議,希望對(duì)你有啟發(fā)。

程序員的三個(gè)階段

第一階段-——三年

我認(rèn)為三年對(duì)于程序員來(lái)說(shuō)是第一個(gè)門檻,這個(gè)階段將會(huì)淘汰掉一批不適合寫代碼的人。這一階段,我們走出校園,邁入社會(huì),成為一名程序員,正式從書(shū)本上的內(nèi)容邁向真正的企業(yè)級(jí)開(kāi)發(fā)。我們知道如何團(tuán)隊(duì)協(xié)作、如何使用項(xiàng)目管理工具、項(xiàng)目版本如何控制、我們寫的代碼如何測(cè)試如何在線上運(yùn)行等等,積累了一定的開(kāi)發(fā)經(jīng)驗(yàn),也對(duì)代碼有了一定深入的認(rèn)識(shí),是一個(gè)比較純粹的Coder的階段。

第二階段——五年

五年又是區(qū)分程序員的第二個(gè)門檻。有些人在三年里,除了完成工作,在空余時(shí)間基本不會(huì)研究別的東西, 熱衷于研究各種技術(shù)實(shí)現(xiàn)細(xì)節(jié)、看了N多好書(shū)、寫一些博客、在Github上分享技術(shù),這些人在五年后必然具備在技術(shù)上獨(dú)當(dāng)一面的能力并且清楚自己未來(lái)的發(fā)展方向,從一個(gè)Coder逐步走向系統(tǒng)分析師或是架構(gòu)師,成為項(xiàng)目組中不可或缺的人物。

第三階段——十年 

十年又是另一個(gè)門檻了,轉(zhuǎn)行或是繼續(xù)做一名程序員就在這個(gè)節(jié)點(diǎn)上。如果在前幾年就抱定不轉(zhuǎn)行的思路并且為之努力的話,那么在十年的這個(gè)節(jié)點(diǎn)上,有些人必然成長(zhǎng)為一名對(duì)行業(yè)有著深入認(rèn)識(shí)、對(duì)技術(shù)有著深入認(rèn)識(shí)、能從零開(kāi)始對(duì)一個(gè)產(chǎn)品進(jìn)行分析的程序員,這樣的人在公司基本擔(dān)任的都是CTO、技術(shù)專家、首席架構(gòu)師等最關(guān)鍵的職位,這對(duì)于自己絕對(duì)是一件榮耀的事,當(dāng)然老板在經(jīng)濟(jì)上也絕不會(huì)虧待你 

總結(jié)一下,我認(rèn)為,隨著你工作年限的增長(zhǎng)、對(duì)生活對(duì)生命認(rèn)識(shí)的深入,應(yīng)當(dāng)不斷思考三個(gè)問(wèn)題: 

  1. 我到底適不適合當(dāng)一名程序員?
  2. 我到底應(yīng)不應(yīng)該一輩子以程序員為職業(yè)?
  3. 我對(duì)編程到底持有的是一種什么樣的態(tài)度,是夠用就好呢還是不斷研究?

最終,明確自己的職業(yè)規(guī)劃,對(duì)自己的規(guī)劃負(fù)責(zé)并為之努力。                                                                                                                                          

關(guān)于專業(yè)技能

一名3年工作經(jīng)驗(yàn)的Java程序員應(yīng)該具備的技能,這可能是Java程序員們比較關(guān)心的內(nèi)容。我這里要說(shuō)明一下,以下列舉的內(nèi)容不是都要會(huì)的東西----但是如果你掌握得越多,最終能得到的評(píng)價(jià)、拿到的薪水勢(shì)必也越高。

1、基本語(yǔ)法

這包括static、final、transient等關(guān)鍵字的作用,foreach循環(huán)的原理等等。今天面試我問(wèn)你static關(guān)鍵字有哪些作用,如果你答出static修飾變量、修飾方法我會(huì)認(rèn)為你合格,答出靜態(tài)塊,我會(huì)認(rèn)為你不錯(cuò),答出靜態(tài)內(nèi)部類我會(huì)認(rèn)為你很好,答出靜態(tài)導(dǎo)包我會(huì)對(duì)你很滿意,因?yàn)槟芸闯瞿惴浅嶂匝芯考夹g(shù)。

讓我印象深刻的一次面試經(jīng)歷,面試官直接問(wèn)到了我volatile關(guān)鍵字的底層實(shí)現(xiàn)原理(順便插一句,面試和被面試本身就是相對(duì)的,面試官能問(wèn)這個(gè)問(wèn)題同時(shí)也讓面試者感覺(jué)到面試官也是一個(gè)喜愛(ài)研究技術(shù)的人,增加了面試者對(duì)公司的好感,我最終選擇的就是問(wèn)了這個(gè)問(wèn)題的公司),不要覺(jué)得這太吹毛求疵了----越簡(jiǎn)單的問(wèn)題越能看出一個(gè)人的水平,別人對(duì)你技術(shù)的考量絕大多數(shù)都是以深度優(yōu)先、廣度次之為標(biāo)準(zhǔn)的,切記。

2、集合

非常重要,也是必問(wèn)的內(nèi)容?;旧暇褪荓ist、Map、Set,問(wèn)的是各種實(shí)現(xiàn)類的底層實(shí)現(xiàn)原理,實(shí)現(xiàn)類的優(yōu)缺點(diǎn)。

集合要掌握的是ArrayList、LinkedList、Hashtable、HashMap、ConcurrentHashMap、HashSet的實(shí)現(xiàn)原理,能流利作答,當(dāng)然能掌握CopyOnWrite容器和Queue是再好不過(guò)的了。另外多說(shuō)一句,ConcurrentHashMap的問(wèn)題在面試中問(wèn)得特別多,大概是因?yàn)檫@個(gè)類可以衍生出非常多的問(wèn)題,關(guān)于ConcurrentHashMap,我提供三點(diǎn)回答或者是研究方向:

  1. ConcurrentHashMap的鎖分段技術(shù)
  2. ConcurrentHashMap的讀是否要加鎖,為什么
  3. ConcurrentHashMap的迭代器是強(qiáng)一致性的迭代器還是弱一致性的迭代器

3、設(shè)計(jì)模式

本來(lái)以為蠻重要的一塊內(nèi)容,結(jié)果只在阿里巴巴B2B事業(yè)部面試的時(shí)候被問(wèn)了一次,當(dāng)時(shí)問(wèn)的是裝飾器模式。 

當(dāng)然咱們不能這么功利,為了面試而學(xué)習(xí),設(shè)計(jì)模式在工作中還是非常重要、非常有用的,23種設(shè)計(jì)模式中重點(diǎn)研究常用的十來(lái)種就可以了,面試中關(guān)于設(shè)計(jì)模式的問(wèn)答主要是三個(gè)方向:

  1. 你的項(xiàng)目中用到了哪些設(shè)計(jì)模式,如何使用
  2. 知道常用設(shè)計(jì)模式的優(yōu)缺點(diǎn)
  3. 能畫出常用設(shè)計(jì)模式的UML圖

4、多線程

這也是必問(wèn)的一塊了。因?yàn)槿旯ぷ鹘?jīng)驗(yàn),所以基本上不會(huì)再問(wèn)你怎么實(shí)現(xiàn)多線程了,會(huì)問(wèn)得深入一些比如說(shuō)Thread和Runnable的區(qū)別和聯(lián)系、多次start一個(gè)線程會(huì)怎么樣、線程有哪些狀態(tài)。當(dāng)然這只是最基本的,出乎意料地,幾次面試幾乎都被同時(shí)問(wèn)到了一個(gè)問(wèn)題,問(wèn)法不盡相同,總結(jié)起來(lái)是這么一個(gè)意思:

假如有Thread1、Thread2、Thread3、Thread4四條線程分別統(tǒng)計(jì)C、D、E、F四個(gè)盤的大小,所有線程都統(tǒng)計(jì)完畢交給Thread5線程去做匯總,應(yīng)當(dāng)如何實(shí)現(xiàn)?

你對(duì)這個(gè)問(wèn)題是否有答案呢?不難,java.util.concurrent下就有現(xiàn)成的類可以使用。

另外,線程池也是比較常問(wèn)的一塊,常用的線程池有幾種?這幾種線程池之間有什么區(qū)別和聯(lián)系?線程池的實(shí)現(xiàn)原理是怎么樣的?實(shí)際一些的,會(huì)給你一些具體的場(chǎng)景,讓你回答這種場(chǎng)景該使用什么樣的線程池比較合適。

最后,雖然這次面試問(wèn)得不多,但是多線程同步、鎖這塊也是重點(diǎn)。synchronized和ReentrantLock的區(qū)別、synchronized鎖普通方法和鎖靜態(tài)方法、死鎖的原理及排查方法等等... 

5、 IO

IO分為File IO和Socket IO,F(xiàn)ile IO基本上是不會(huì)問(wèn)的,問(wèn)也問(wèn)不出什么來(lái),平時(shí)會(huì)用就好了,另外記得File IO都是阻塞IO。 

Socket IO是比較重要的一塊,要搞懂的是阻塞/非阻塞的區(qū)別、同步/異步的區(qū)別,借此理解阻塞IO、非阻塞IO、多路復(fù)用IO、異步IO這四種IO模型,Socket IO如何和這四種模型相關(guān)聯(lián)。這是基本一些的,深入一些的話,就會(huì)問(wèn)NIO的原理、NIO屬于哪種IO模型、NIO的三大組成等等,這有些難,當(dāng)時(shí)我也是研究了很久才搞懂NIO。

提一句,NIO并不是嚴(yán)格意義上的非阻塞IO而應(yīng)該屬于多路復(fù)用IO,面試回答的時(shí)候要注意這個(gè)細(xì)節(jié),講到NIO會(huì)阻塞在Selector的select方法上會(huì)增加面試官對(duì)你的好感。

如果用過(guò)Netty,可能會(huì)問(wèn)一些Netty的東西,畢竟這個(gè)框架基本屬于當(dāng)前最好的NIO框架了(Mina其實(shí)也不錯(cuò),不過(guò)總體來(lái)說(shuō)還是比不上Netty的),大多數(shù)互聯(lián)網(wǎng)公司也都在用Netty。

6、JDK源碼

要想拿高工資,JDK源碼不可不讀。上面的內(nèi)容可能還和具體場(chǎng)景聯(lián)系起來(lái),JDK源碼就是實(shí)打?qū)嵉乜茨闫綍r(shí)是不是愛(ài)鉆研了。我面試過(guò)程中被問(wèn)了不少JDK源碼的問(wèn)題,其中最刁鉆的一個(gè)問(wèn)題——String的hashCode()方法是怎么實(shí)現(xiàn)的,幸好我平時(shí)String源代碼看得多,答了個(gè)大概。JDK源碼其實(shí)沒(méi)什么好總結(jié)的,純粹看個(gè)人,總結(jié)一下比較重要的源碼:

List、Map、Set實(shí)現(xiàn)類的源代碼

ReentrantLock、AQS的源代碼

AtomicInteger的實(shí)現(xiàn)原理,主要能說(shuō)清楚CAS機(jī)制并且AtomicInteger是如何利用CAS機(jī)制實(shí)現(xiàn)的

線程池的實(shí)現(xiàn)原理

Object類中的方法以及每個(gè)方法的作用

這些其實(shí)要求蠻高的,我去年一整年基本把JDK中重要類的源代碼研究了個(gè)遍,真的花費(fèi)時(shí)間、花費(fèi)精力,當(dāng)然回頭看,是值得的----不僅僅是為了應(yīng)付面試。

7、 框架

老生常談,面試必問(wèn)的東西。一般來(lái)說(shuō)會(huì)問(wèn)你一下你們項(xiàng)目中使用的框架,然后給你一些場(chǎng)景問(wèn)你用框架怎么做,比如我想要在spring初始化bean的時(shí)候做一些事情該怎么做、想要在bean銷毀的時(shí)候做一些事情該怎么做、MyBatis中$和#的區(qū)別等等,這些都比較實(shí)際了,平時(shí)積累得好、有多學(xué)習(xí)框架的使用細(xì)節(jié)自然都不成問(wèn)題。 

如果上面你的問(wèn)題答得好,面試官往往會(huì)深入地問(wèn)一些框架的實(shí)現(xiàn)原理。問(wèn)得最多的就是Spring AOP的實(shí)現(xiàn)原理,當(dāng)然這個(gè)很簡(jiǎn)單啦,兩句話就搞定的的事兒,即使你不會(huì)準(zhǔn)備一下就好了。我遇到的最變態(tài)的是讓我畫一下Spring的Bean工廠實(shí)現(xiàn)的UML圖,當(dāng)然面對(duì)這樣一個(gè)有深度的問(wèn)題,我是絕對(duì)答不出來(lái)的......

8、數(shù)據(jù)庫(kù)

數(shù)據(jù)庫(kù)十有八九也都會(huì)問(wèn)到。一些基本的像union和union all的區(qū)別、left join、幾種索引及其區(qū)別就不談了,比較重要的就是數(shù)據(jù)庫(kù)性能的優(yōu)化,如果對(duì)于數(shù)據(jù)庫(kù)的性能優(yōu)化一竅不通,那么有時(shí)間,還是建議你在面試前花一兩天專門把SQL基礎(chǔ)和SQL優(yōu)化的內(nèi)容準(zhǔn)備一下。

不過(guò)數(shù)據(jù)庫(kù)倒是不用擔(dān)心,一家公司往往有很多部門,如果你對(duì)數(shù)據(jù)庫(kù)不熟悉而基本技術(shù)又非常好,九成都是會(huì)要你的,估計(jì)會(huì)先把你放到對(duì)數(shù)據(jù)庫(kù)使用不是要求非常高的部門鍛煉一下。

9、數(shù)據(jù)結(jié)構(gòu)和算法分析 

數(shù)據(jù)結(jié)構(gòu)和算法分析,對(duì)于一名程序員來(lái)說(shuō),會(huì)比不會(huì)好而且在工作中絕對(duì)能派上用場(chǎng)。數(shù)組、鏈表是基礎(chǔ),棧和隊(duì)列深入一些但也不難,樹(shù)挺重要的,比較重要的樹(shù)AVL樹(shù)、紅黑樹(shù),可以不了解它們的具體實(shí)現(xiàn),但是要知道什么是二叉查找樹(shù)、什么是平衡樹(shù),AVL樹(shù)和紅黑樹(shù)的區(qū)別。記得某次面試,某個(gè)面試官和我聊到了數(shù)據(jù)庫(kù)的索引,他問(wèn)我:

你知道索引使用的是哪種數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn)嗎?

我答到用的Hash表吧,答錯(cuò)。他又問(wèn),你知道為什么要使用樹(shù)嗎?我答到因?yàn)镠ash表可能會(huì)出現(xiàn)比較多的沖突,在千萬(wàn)甚至是上億級(jí)別的數(shù)據(jù)面前,會(huì)大大增加查找的時(shí)間復(fù)雜度。而樹(shù)比較穩(wěn)定,基本保證最多二三十次就能找到想要的數(shù)據(jù),對(duì)方說(shuō)不完全對(duì),最后我們還是交流了一下這個(gè)問(wèn)題,我也明白了為什么要使用樹(shù),這里不說(shuō),大家覺(jué)得索引為什么要使用樹(shù)來(lái)實(shí)現(xiàn)呢?

至于算法分析,不會(huì)、不想研究就算了,記得某次面試對(duì)方問(wèn)我,Collections.sort方法使用的是哪種排序方法,額,吐血三升。當(dāng)然為了顯示我的博學(xué),對(duì)算法分析也有一定的研究,我還是硬著頭皮說(shuō)了一句可能是冒泡排序吧。當(dāng)然答案肯定不是,有興趣的朋友可以去看一下Collections.sort方法的源代碼,用的是一種叫做TimSort的排序法,也就是增強(qiáng)型的歸并排序法。

10、 Java虛擬機(jī)

出乎我意料,Java虛擬機(jī)應(yīng)該是很重要的一塊內(nèi)容,結(jié)果在這幾家公司中被問(wèn)到的概率幾乎為0。要知道,我去年可是花了大量的時(shí)間去研究Java虛擬機(jī)的,光周志明老師的《深入理解Java虛擬機(jī):JVM高級(jí)特性與最佳實(shí)踐》,就讀了不下五遍。

言歸正傳,雖然Java虛擬機(jī)沒(méi)問(wèn)到,但我覺(jué)得還是有必要研究的,我就簡(jiǎn)單地列一個(gè)提綱吧,談?wù)凧ava虛擬機(jī)中比較重要的內(nèi)容: 

  1. Java虛擬機(jī)的內(nèi)存布局
  2. GC算法及幾種垃圾收集器
  3. 類加載機(jī)制,也就是雙親委派模型
  4. Java內(nèi)存模型
  5. happens-before規(guī)則
  6. volatile關(guān)鍵字使用規(guī)則
  7. 也許面試無(wú)用,但在走向大牛的路上,不可不會(huì)。

11、Web方面的一些問(wèn)題 

Java主要面向Web端,因此Web的一些問(wèn)題也是必問(wèn)的。我碰到過(guò)問(wèn)得最多的兩個(gè)問(wèn)題是:

      1.談?wù)劮植际絊ession的幾種實(shí)現(xiàn)方式

        常用的四種能答出來(lái)自然是讓面試官非常滿意的,另外一個(gè)常問(wèn)的問(wèn)題是:

      2.講一下Session和Cookie的區(qū)別和聯(lián)系以及Session的實(shí)現(xiàn)原理

這兩個(gè)問(wèn)題之外,web.xml里面的內(nèi)容是重點(diǎn),F(xiàn)ilter、Servlet、Listener,不說(shuō)對(duì)它們的實(shí)現(xiàn)原理一清二楚吧,至少能對(duì)它們的使用知根知底。另外,一些細(xì)節(jié)的方面比如get/post的區(qū)別、forward/重定向的區(qū)別、HTTPS的實(shí)現(xiàn)原理也都可能會(huì)被考察到。

最后,如果有興趣有時(shí)間,建議學(xué)習(xí)、研究一下SOA和RPC,面向服務(wù)體系,大型分布式架構(gòu)必備,救命良方、包治百病、屢試不爽。 

責(zé)任編輯:龐桂玉 來(lái)源: Android技術(shù)之家
相關(guān)推薦

2018-03-13 08:48:26

java程序員技能

2017-12-26 15:30:06

Java程序員技能

2016-03-14 11:58:10

面試工作經(jīng)驗(yàn)程序員

2011-03-14 10:56:56

程序員人才

2016-03-21 13:29:40

程序員51CTO IT技術(shù)周刊

2015-07-15 09:53:16

程序員開(kāi)發(fā)類工具

2009-04-14 11:13:22

主流開(kāi)發(fā)開(kāi)發(fā)技能程序員

2020-03-09 21:08:47

虛擬化邊緣計(jì)算

2012-11-30 11:29:05

高級(jí)程序員程序員

2014-07-30 16:11:11

程序員

2014-08-04 10:54:47

程序員

2009-02-23 20:45:54

程序員基本素質(zhì)

2019-09-16 09:46:05

程序員技術(shù)等級(jí)

2021-04-13 09:07:12

程序員工具軟件開(kāi)發(fā)

2015-09-08 10:49:35

程序員編程經(jīng)驗(yàn)

2020-07-17 10:09:44

程序員技術(shù)開(kāi)發(fā)

2013-06-18 10:58:26

IT人員軟技能

2021-06-02 05:47:32

程序員編程開(kāi)發(fā)

2009-06-05 12:51:34

遭軟裁員工作經(jīng)驗(yàn)

2019-08-19 08:42:44

程序員技能開(kāi)發(fā)者
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)