創(chuàng)新互聯(lián)www.cdcxhl.cn八線動(dòng)態(tài)BGP香港云服務(wù)器提供商,新人活動(dòng)買多久送多久,劃算不套路!
創(chuàng)新互聯(lián)建站主要從事成都做網(wǎng)站、成都網(wǎng)站設(shè)計(jì)、網(wǎng)頁設(shè)計(jì)、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)祁連,十載網(wǎng)站建設(shè)經(jīng)驗(yàn),價(jià)格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):028-86922220小編這次要給大家分享的是具有3年工作經(jīng)驗(yàn)的java程序員應(yīng)該具備哪些技術(shù)能力,文章內(nèi)容豐富,感興趣的小伙伴可以來了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。
3年工作經(jīng)驗(yàn)的Java程序員應(yīng)該具備哪些技術(shù)能力,這可能是Java程序員們比較關(guān)心的內(nèi)容。我這里要說明一下,以下列舉的內(nèi)容不是都要會(huì)的東西,但是你掌握得越多,最終能得到的評價(jià)、拿到的薪水勢必也越高。
1、基本語法
這包括static、final、transient等關(guān)鍵字的作用,foreach循環(huá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ì)對你很滿 意,因?yàn)槟芸闯瞿惴浅嶂匝芯考夹g(shù)。
最深入的一次,我記得面試官直接問到了我Volatile關(guān) 鍵字的底層實(shí)現(xiàn)原理(順便插一句,面試和被面試本身就是相對的,面試官能問這個(gè)問題同時(shí)也讓面試者感覺到面試官也是一個(gè)喜愛研究技術(shù)的人,增加了面試者對 公司的好感,我最終選擇的就是問了這個(gè)問題的公司),不要覺得這太吹毛求疵了—-越簡單的問題越能看出一個(gè)人的水平,別人對你技術(shù)的考量絕大多數(shù)都是以深度優(yōu)先、廣度次之為標(biāo)準(zhǔn)的,切記。
2、集合
非常重要,也是必問的內(nèi)容?;旧暇褪荓ist、Map、Set,問的是各種實(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是再好不過的了。另外多說一 句,ConcurrentHashMap的問題在面試中問得特別多,大概是因?yàn)檫@個(gè)類可以衍生出非常多的問題,關(guān)于ConcurrentHashMap, 我給網(wǎng)友朋友們提供三點(diǎn)回答或者是研究方向:
(1)ConcurrentHashMap的鎖分段技術(shù)。
(2)ConcurrentHashMap的讀是否要加鎖,為什么。
(3)ConcurrentHashMap的迭代器是強(qiáng)一致性的迭代器還是弱一致性的迭代器。
3、框架
老生常談,面試必問的東西。一般來說會(huì)問你一下你們項(xiàng)目中使用的框架,然后給你一些場景問你用框架怎么做,比如我想要在Spring初始化bean 的時(shí)候做一些事情該怎么做、想要在bean銷毀的時(shí)候做一些事情該怎么做、MyBatis中$和#的區(qū)別等等,這些都比較實(shí)際了,平時(shí)積累得好、有多學(xué)習(xí) 框架的使用細(xì)節(jié)自然都不成問題。
如果上面你的問題答得好,面試官往往會(huì)深入地問一些框架的實(shí)現(xiàn)原理。問得最多的就是Spring AOP的實(shí)現(xiàn)原理,當(dāng)然這個(gè)很簡單啦,兩句話就搞定的的事兒,即使你不會(huì)準(zhǔn)備一下就好了。我遇到的最變態(tài)的是讓我畫一下Spring的Bean工廠實(shí) 現(xiàn)的UML圖,當(dāng)然面對這樣一個(gè)有深度的問題,我是絕對答不出來的/(ㄒoㄒ)/~~
4、數(shù)據(jù)庫
數(shù)據(jù)庫十有八九也都會(huì)問到。一些基本的像和 all的區(qū)別、left join、幾種索引及其區(qū)別就不談了,比較重要的就是數(shù)據(jù)庫性能的優(yōu)化,如果對于數(shù)據(jù)庫的性能優(yōu)化一竅不通,那么有時(shí)間,還是建議你在面試前花一兩天專門 把SQL基礎(chǔ)和SQL優(yōu)化的內(nèi)容準(zhǔn)備一下。
不過數(shù)據(jù)庫倒是不用擔(dān)心,一家公司往往有很多部門,如果你對數(shù)據(jù)庫不熟悉而基本技術(shù)又非常好,九成都是會(huì)要你的,估計(jì)會(huì)先把你放到對數(shù)據(jù)庫使用不是要求非常高的部門鍛煉一下。
5、Web方面的一些問題
Java主要面向Web端,因此Web的一些問題也是必問的。
我碰到過問得最多的兩個(gè)問題是:
談?wù)劮植际絊ession的幾種實(shí)現(xiàn)方式。
常用的四種能答出來自然是讓面試官非常滿意的。
另外一個(gè)常問的問題是:講一下Session和Cookie的區(qū)別和聯(lián)系以及Session的實(shí)現(xiàn)原理。這兩個(gè)問題之外,web.xml里面的內(nèi)容是重點(diǎn),F(xiàn)ilter、Servlet、Listener,不說對它們的實(shí)現(xiàn)原理一清二楚吧,至少能對它們的使用知根知底。另外,一些細(xì)節(jié)的方面比如get/post的區(qū)別、forward/重定向的區(qū)別、HTTPS的實(shí)現(xiàn)原理也都可能會(huì)被考察到。
6、數(shù)據(jù)結(jié)構(gòu)和算法分析
數(shù)據(jù)結(jié)構(gòu)和算法分析,對于一名程序員來說,會(huì)比不會(huì)好而且在工作中絕對能派上用場。數(shù)組、鏈表是基礎(chǔ),棧和隊(duì)列深入一些但也不難,樹挺重要的,比較 重要的樹AVL樹、紅黑樹,可以不了解它們的具體實(shí)現(xiàn),但是要知道什么是二叉查找樹、什么是平衡樹,AVL樹和紅黑樹的區(qū)別。記得某次面試,某個(gè)面試官和 我聊到了數(shù)據(jù)庫的索引,他問我:你知道索引使用的是哪種數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn)嗎?
我答到用的Hash表吧,答錯(cuò)。他又問,你知道為什么要使用樹嗎?我答到因?yàn)镠ash表可能會(huì)出現(xiàn)比較多的沖突,在千萬甚至是上億級別的數(shù)據(jù)面 前,會(huì)大大增加查找的時(shí)間復(fù)雜度。而樹比較穩(wěn)定,基本保證最多二三十次就能找到想要的數(shù)據(jù),對方說不完全對,最后我們還是交流了一下這個(gè)問題,我也明白了 為什么要使用樹,這里不說,網(wǎng)友朋友們覺得索引為什么要使用樹來實(shí)現(xiàn)呢?
至于算法分析,不會(huì)、不想研究就算了,記得某次面試對方問我,Collections.sort方法使用的是哪種排序方法,額,吐血三升。當(dāng)然為了 顯示我的博學(xué),對算法分析也有一定的研究(⊙﹏⊙)b,我還是硬著頭皮說了一句可能是冒泡排序吧。當(dāng)然答案肯定不是,有興趣的網(wǎng)友朋友們可以去看一下 Collections.sort方法的源代碼,用的是一種叫做TimSort的排序法,也就是增強(qiáng)型的歸并排序法。
7、Java虛擬機(jī)
出乎我的意料,Java虛擬機(jī)應(yīng)該是很重要的一塊內(nèi)容,結(jié)果在這幾家公司中被問到的概率幾乎為0。要知道,我去年可是花了大量的時(shí)間去研究Java虛擬機(jī)的,光周志明老師的《深入理解Java虛擬機(jī):JVM高級特性與最佳實(shí)踐》,我就讀了不下五遍。
言歸正傳,雖然Java虛擬機(jī)沒問到,但我覺得還是有必要研究的,我就簡單地列一個(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ī)則
也許面試無用,但在走向大牛的路上,不可不會(huì)。
8、設(shè)計(jì)模式
本來以為蠻重要的一塊內(nèi)容,結(jié)果只在阿里巴巴B2B事業(yè)部面試的時(shí)候被問了一次,當(dāng)時(shí)問的是裝飾器模式。
當(dāng)然咱們不能這么功利,為了面試而學(xué)習(xí),設(shè)計(jì)模式在工作中還是非常重要、非常有用的,23種設(shè)計(jì)模式中重點(diǎn)研究常用的十來種就可以了,面試中關(guān)于設(shè)計(jì)模式的問答主要是三個(gè)方向:
(1)你的項(xiàng)目中用到了哪些設(shè)計(jì)模式,如何使用。
(2)知道常用設(shè)計(jì)模式的優(yōu)缺點(diǎn)。
(3)能畫出常用設(shè)計(jì)模式的UML圖。
9、多線程
這也是必問的一塊了。因?yàn)槿旯ぷ鹘?jīng)驗(yàn),所以基本上不會(huì)再問你怎么實(shí)現(xiàn)多線程了,會(huì)問得深入一些比如說Thread和Runnable的區(qū)別和聯(lián) 系、多次start一個(gè)線程會(huì)怎么樣、線程有哪些狀態(tài)。當(dāng)然這只是最基本的,出乎意料地,幾次面試幾乎都被同時(shí)問到了一個(gè)問題,問法不盡相同。
總結(jié)起來是 這么一個(gè)意思:
假如有Thread1、Thread2、ThreaD3、Thread4四條線程分別統(tǒng)計(jì)C、D、E、F四個(gè)盤的大小,所有線程都統(tǒng)計(jì)完畢交給Thread5線程去做匯總,應(yīng)當(dāng)如何實(shí)現(xiàn)?
聰明的網(wǎng)友們對這個(gè)問題是否有答案呢?不難,java.util.concurrent下就有現(xiàn)成的類可以使用。
另外,線程池也是比較常問的一塊,常用的線程池有幾種?這幾種線程池之間有什么區(qū)別和聯(lián)系?線程池的實(shí)現(xiàn)原理是怎么樣的?實(shí)際一些的,會(huì)給你一些具體的場景,讓你回答這種場景該使用什么樣的線程池比較合適。
最后,雖然這次面試問得不多,但是多線程同步、鎖這塊也是重點(diǎn)。synchronized和ReentrantLock的區(qū)別、 synchronized鎖普通方法和鎖靜態(tài)方法、死鎖的原理及排查方法等等。
10、JDK源碼
要想拿高工資,JDK源碼不可不讀。上面的內(nèi)容可能還和具體場景聯(lián)系起來,JDK源碼就是實(shí)打?qū)嵉乜茨闫綍r(shí)是不是愛鉆研了。我面試過程中被問了不 少JDK源碼的問題,其中最刁鉆的一個(gè)問了我,String的hashCode()方法是怎么實(shí)現(xiàn)的,幸好我平時(shí)String源代碼看得多,答了個(gè)大 概。
JDK源碼其實(shí)沒什么好總結(jié)的,純粹看個(gè)人,總結(jié)一下比較重要的源碼:
(1)List、Map、Set實(shí)現(xiàn)類的源代碼
(2)ReentrantLock、AQS的源代碼
(3)AtomicInteger的實(shí)現(xiàn)原理,主要能說清楚CAS機(jī)制并且AtomicInteger是如何利用CAS機(jī)制實(shí)現(xiàn)的
(4)線程池的實(shí)現(xiàn)原理
(5)Object類中的方法以及每個(gè)方法的作用
這些其實(shí)要求蠻高的,我去年一整年基本把JDK中重要類的源代碼研究了個(gè)遍,真的花費(fèi)時(shí)間、花費(fèi)精力,當(dāng)然回頭看,是值得的—-不僅僅是為了應(yīng)付面試。
最后,如果有興趣有時(shí)間,建議學(xué)習(xí)、研究一下SOA和RPC,面向服務(wù)體系,大型分布式架構(gòu)必備,救命良方、包治百病、屢試不爽。
11、建議
每個(gè)階段都應(yīng)該有每個(gè)階段的目標(biāo),無論生活上,學(xué)習(xí)上或工作上,我們都需要定目標(biāo),這樣做起事情來才有方向才有動(dòng)力哦;而且做起事情來有節(jié)奏,不亂套。如果不設(shè)定目標(biāo),你會(huì)覺得自己每天不知要干些什么;不知先做什么,后做什么;人也會(huì)覺得懶散。
看完這篇關(guān)于具有3年工作經(jīng)驗(yàn)的java程序員應(yīng)該具備哪些技術(shù)能力的文章,如果覺得文章內(nèi)容寫得不錯(cuò)的話,可以把它分享出去給更多人看到。
分享標(biāo)題:具有3年工作經(jīng)驗(yàn)的java程序員應(yīng)該具備哪些技術(shù)能力-創(chuàng)新互聯(lián)
文章位置:http://www.rwnh.cn/article20/dhhsjo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供Google、品牌網(wǎng)站制作、網(wǎng)站制作、電子商務(wù)、微信小程序、全網(wǎng)營銷推廣
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容