想要成為合格的Java程序員或工程師到底需要具備哪些專業(yè)技能,面試者在面試之前到底需要準(zhǔn)備哪些東西呢?本文陳列的這些內(nèi)容既可以作為個(gè)人簡(jiǎn)歷中的內(nèi)容,也可以作為面試的時(shí)候跟面試官聊的東西,你可以把這些內(nèi)容寫到你的簡(jiǎn)歷中,當(dāng)然更需要的是你在面試的時(shí)候向面試官展示這些專業(yè)技能。相信此文對(duì)正在尋覓Java程序員(Java工程師)職位的freshman以及希望成為中高級(jí)Java開發(fā)者的junior都會(huì)有所幫助。
專業(yè)技能
- 熟練的使用Java語言進(jìn)行面向?qū)ο蟪绦蛟O(shè)計(jì),有良好的編程習(xí)慣,熟悉常用的Java API,包括集合框架(容器)、多線程(并發(fā)編程)、I/O(BIO、NIO、AIO)、Socket、JDBC、注解、反射等,熟悉Java語言新特性(Lambda表達(dá)式、流式操作等)。
- 熟悉基于JSP和Servlet的Java Web開發(fā),對(duì)Servlet和JSP的工作原理和生命周期有深入了解,熟練的使用JSTL和EL編寫無腳本動(dòng)態(tài)頁面,有使用監(jiān)聽器、過濾器等Web組件以及MVC架構(gòu)模式進(jìn)行Java Web項(xiàng)目開發(fā)的經(jīng)驗(yàn),熟悉基于模板引擎(FreeMarker、Velocity)的動(dòng)態(tài)頁面生成。
- 對(duì)Spring的IoC容器和AOP原理有深入了解,熟練的運(yùn)用Spring框架管理各種Web組件及其依賴關(guān)系,熟練的使用Spring進(jìn)行事務(wù)、日志、安全性等的管理,有使用Spring MVC進(jìn)行Web項(xiàng)目開發(fā)的經(jīng)驗(yàn),熟悉Spring對(duì)其他框架的整合(SSH、SSM、SSS)。
- 熟練的使用Hibernate、MyBatis等ORM框架,熟悉Hibernate和MyBatis的核心API,對(duì)Hibernate的關(guān)聯(lián)映射、繼承映射、組件映射、緩存機(jī)制、事務(wù)管理以及性能調(diào)優(yōu)等有深入的理解。
- 熟練的使用HTML、CSS和JavaScript進(jìn)行Web前端開發(fā),熟悉jQuery和Bootstrap,對(duì)Ajax技術(shù)在Web項(xiàng)目中的應(yīng)用有深入理解,有使用前端MVC框架(AngularJS、Vue.js)和JavaScript模板引擎(Handlebars.js、mustache)進(jìn)行項(xiàng)目開發(fā)的經(jīng)驗(yàn)。
- 熟悉常用的關(guān)系型數(shù)據(jù)庫產(chǎn)品(MySQL、Oracle),熟練使用SQl,了解NoSQL數(shù)據(jù)庫產(chǎn)品(Redis、MongoDB、Neo4j)。
- 熟悉面向?qū)ο蟮脑O(shè)計(jì)原則,對(duì)GoF設(shè)計(jì)模式和企業(yè)應(yīng)用架構(gòu)模式有深入的了解和實(shí)際開發(fā)的相關(guān)經(jīng)驗(yàn),熟練的使用UML進(jìn)行面向?qū)ο蟮姆治龊驮O(shè)計(jì),有TDD(測(cè)試驅(qū)動(dòng)開發(fā))和DDD(領(lǐng)域驅(qū)動(dòng)設(shè)計(jì))的經(jīng)驗(yàn)。
- 熟悉Apache、NginX、Tomcat、Jetty、Weblogic等Web服務(wù)器和應(yīng)用服務(wù)器的使用,熟悉多種服務(wù)器整合、集群和負(fù)載均衡的配置。
- 熟練的使用產(chǎn)品原型工具Axure,熟練的使用設(shè)計(jì)建模工具PowerDesigner和Enterprise Architect,熟練的使用Java開發(fā)環(huán)境Eclipse和IntelliJ,熟練的使用前端開發(fā)環(huán)境WebStorm,熟練的使用軟件版本控制工具SVN和Git,熟練的使用項(xiàng)目構(gòu)建和管理工具M(jìn)aven和Gradle。
說明:上面羅列的這些東西并不是每一項(xiàng)你都要爛熟于心,根據(jù)企業(yè)招聘的具體要求可以做相應(yīng)的有針對(duì)性的準(zhǔn)備。我個(gè)人覺得前6項(xiàng)應(yīng)該是最低要求,是作為一個(gè)Java開發(fā)者必須要具備的專業(yè)技能。
項(xiàng)目經(jīng)驗(yàn)
項(xiàng)目介紹
本系統(tǒng)是X委托Y開發(fā)的用于Z的系統(tǒng),系統(tǒng)包括A、B、C、D等模塊。系統(tǒng)使用了Java企業(yè)級(jí)開發(fā)的開源框架E以及前端技術(shù)F。表示層運(yùn)用了G架構(gòu),使用H作為視圖I作為控制器并實(shí)現(xiàn)了REST風(fēng)格的請(qǐng)求;業(yè)務(wù)邏輯層運(yùn)用了J模式,并通過K實(shí)現(xiàn)事務(wù)、日志和安全性等功能,通過L實(shí)現(xiàn)緩存服務(wù);持久層使用了M封裝CRUD操作,底層使用N實(shí)現(xiàn)數(shù)據(jù)存取。整個(gè)項(xiàng)目采用了P開發(fā)模型。
說明:上面的描述中,E通常指Spring(Java企業(yè)級(jí)開發(fā)的一站式選擇);F最有可能是jQuery庫及其插件或者是Bootstrap框架,當(dāng)然如果要構(gòu)建單頁應(yīng)用(SPA)最佳的方案是前端MVC框架(如AngularJS)和JavaScript模板引擎(如HandleBars);G顯然是MVC(模型-視圖-控制),最有可能的實(shí)現(xiàn)框架是Spring MVC,除此之外還有Struts 2、JSF以及Apache為JSF提供的MyFaces實(shí)現(xiàn),可以使用JSP作為MVC中的V,也可使用模板引擎(如Freemarker和Thymeleaf)來生成視圖,還可以是各種文檔或報(bào)表(如Excel和PDF等),而Servlet和自定義的控制器是MVC中的C,當(dāng)然Spring MVC中提供了作為前端控制器的DispatcherServlet;J通常是事務(wù)腳本,K應(yīng)該是AOP(面向切面編程)技術(shù),L目前廣泛使用的有memcached和Redis;M的選擇方案很多,最有可能的是Hibernate和MyBatis,也可以兩種技術(shù)同時(shí)運(yùn)用,但通常是將增刪改交給Hibernate來處理,而復(fù)雜的查詢則由MyBatis完成,此外OpenJPA、EclipseLink、jOOQ也是優(yōu)秀的持久層解決方案;底層的數(shù)據(jù)存取傳統(tǒng)上是使用關(guān)系型數(shù)據(jù)庫,包括MySQL、Oracle、SQLServer、DB2等,也可以采用NoSQL(如Redis、MongoDB、MemBase、BigTable等)和分布式文件系統(tǒng)(如GFS、HDFS等)等解決方案;項(xiàng)目的開發(fā)模型P可以是瀑布模型、快速原型模型、噴泉模型、RAD模型、敏捷模型(Scrum)等。
項(xiàng)目開發(fā)流程
傳統(tǒng)過程模型
- 可行性分析
- 可行性分析報(bào)告 / 項(xiàng)目開發(fā)計(jì)劃書
- 需求分析
- 需求規(guī)格說明書(用例圖、時(shí)序圖、活動(dòng)圖)
- 界面原型:幫助理解需求、業(yè)務(wù)層設(shè)計(jì)時(shí)推導(dǎo)事務(wù)腳本
- 概要設(shè)計(jì)/詳細(xì)設(shè)計(jì)
- 概要設(shè)計(jì)說明書 / 詳細(xì)設(shè)計(jì)說明書
- 抽取業(yè)務(wù)實(shí)體(領(lǐng)域?qū)ο螅侯悎D、E-R圖
- 分層架構(gòu):確定各層的技術(shù)實(shí)現(xiàn)方案(具體到使用的框架、數(shù)據(jù)庫服務(wù)器、應(yīng)用服務(wù)器等)。業(yè)務(wù)層設(shè)計(jì):事務(wù)腳本模式(事務(wù):用戶發(fā)送一次請(qǐng)求就是一個(gè)事務(wù);腳本:一個(gè)方法或一個(gè)函數(shù);事務(wù)腳本:把一次請(qǐng)求封裝為一個(gè)方法或一個(gè)函數(shù);事務(wù)腳本模式:一個(gè)事務(wù)開始于腳本的打開,終止于腳本的關(guān)閉)。業(yè)務(wù)層涉及的對(duì)象有三種類型:事務(wù)腳本類(封裝了業(yè)務(wù)的流程)、數(shù)據(jù)訪問對(duì)象(DAO,封裝了持久化操作)、數(shù)據(jù)傳輸對(duì)象(DTO,封裝了失血/貧血領(lǐng)域?qū)ο螅咧g的關(guān)系是事務(wù)腳本類組合(聚合)數(shù)據(jù)訪問對(duì)象,這二者都依賴了數(shù)據(jù)傳輸對(duì)象
- 正向工程(UML類圖生成Java代碼)和逆向工程(Java代碼生成UML類圖)
- 數(shù)據(jù)庫物理設(shè)計(jì)(E-R圖轉(zhuǎn)換成表間關(guān)系圖、建庫和建表、使用工具插入測(cè)試數(shù)據(jù))
- 編碼 / 測(cè)試
- 測(cè)試報(bào)告 / 缺陷報(bào)告
- 單元測(cè)試:對(duì)軟件中的最小可測(cè)試單元進(jìn)行檢查和驗(yàn)證,在Java中是對(duì)類中的方法進(jìn)行測(cè)試,可以使用JUnit工具來實(shí)施。
- 集成測(cè)試:集成測(cè)試也叫組裝測(cè)試或聯(lián)合測(cè)試。在單元測(cè)試的基礎(chǔ)上,將所有模塊按照設(shè)計(jì)要求組裝成為子系統(tǒng)進(jìn)行測(cè)試。
- 系統(tǒng)測(cè)試:將已經(jīng)確認(rèn)的軟件、硬件、外設(shè)、網(wǎng)絡(luò)等元素結(jié)合在一起,進(jìn)行信息系統(tǒng)的各種組裝測(cè)試和確認(rèn)測(cè)試,系統(tǒng)測(cè)試是針對(duì)整個(gè)產(chǎn)品系統(tǒng)進(jìn)行的測(cè)試,目的是驗(yàn)證系統(tǒng)是否滿足了需求規(guī)格的定義,找出與需求規(guī)格不符或與之矛盾的地方,從而提出更加完善的方案。
- 驗(yàn)收測(cè)試:在軟件產(chǎn)品完成了單元測(cè)試、集成測(cè)試和系統(tǒng)測(cè)試之后,產(chǎn)品發(fā)布之前所進(jìn)行的軟件測(cè)試活動(dòng)。它是技術(shù)測(cè)試的最后一個(gè)階段,也稱為交付測(cè)試。驗(yàn)收測(cè)試的目的是確保軟件準(zhǔn)備就緒,并且可以讓最終用戶將其用于執(zhí)行軟件的既定功能和任務(wù)。
- 交付 / 維護(hù)
- 用戶手冊(cè) / 操作手冊(cè)
敏捷模型
- 籌備會(huì)議
- 用戶故事
- 產(chǎn)品Backlog
- 計(jì)劃會(huì)議
- 分解功能點(diǎn)
- 估算工作量
- 確定優(yōu)先級(jí)
- 日常開發(fā)
- 站立會(huì)議
- 編碼/測(cè)試/修復(fù)
- 評(píng)審會(huì)議
- Show-Case
- 經(jīng)驗(yàn)和教訓(xùn)
項(xiàng)目管理
- 版本控制:SVN / Git
- 自動(dòng)構(gòu)建:Maven / Gradle
- 持續(xù)集成:Jenkins / Travis-CI
系統(tǒng)架構(gòu)
- 負(fù)載均衡
- 硬件:F5、A10
- 軟件:NginX、LVS、HAProxy
- 應(yīng)用服務(wù)器:
- HTTP服務(wù)器:Apache、NginX(HTTP、反向代理、郵件代理服務(wù)器)
- Servlet容器:Tomcat、Resin
- EJB容器:WildFly(JBoss Application Server)、GlassFish、Weblogic、Websphere
- 數(shù)據(jù)庫服務(wù)器
- 關(guān)系型:MySQL、Oracle
- 非關(guān)系型:Redis、MongoDB
第三方庫、中間件和工具
- JSON轉(zhuǎn)換:Gson、Jackson、fastjson等。
- 報(bào)表工具:iReport、DynamicReports、POI、iText等。
- 工作流引擎:jBPM、Activiti、Snaker等。
- 作業(yè)調(diào)度:Quartz、JobServer、Oddjob等。
- 緩存服務(wù):Redis、Ehcache、memcached、Infinispan等。
- 消息隊(duì)列:RabbitMQ、ZeroMQ、ActiveMQ、RocketMQ、Redis等。
- 分布式服務(wù)框架:Dubbo、gRPC、Thrift等。
- 數(shù)據(jù)庫中間件:MySQL-Proxy、Atlas、TDDL、cobar、MyCat等。
- 安全框架:Shiro、Spring Security等。
- 搜索引擎:Solr/Lucene、ElasticSearch等。
- Ajax框架:jQuery、Zepto.js等。
- 圖表庫:ECharts、Chart.js等。
- UI插件:EasyUI、MiniUI等。
- 富文本框:UEditor、CKEditor等。
面試提問
- 項(xiàng)目是為哪個(gè)公司開發(fā)的?項(xiàng)目的投入是多少?
- 有多少人參與了項(xiàng)目開發(fā)?整個(gè)團(tuán)隊(duì)中,測(cè)試人員、開發(fā)人員、項(xiàng)目經(jīng)理比例是多少?
- 項(xiàng)目開發(fā)了多長(zhǎng)時(shí)間?項(xiàng)目總的代碼量有多少?你的代碼量有多少?
- 項(xiàng)目采用了怎樣的開發(fā)模型或開發(fā)流程?項(xiàng)目的架構(gòu)是怎樣的?項(xiàng)目的技術(shù)選型是怎樣的?
- 你在項(xiàng)目中承擔(dān)了怎樣的職責(zé)?是否經(jīng)常開會(huì)或加班?項(xiàng)目完成后有哪些收獲或是經(jīng)驗(yàn)教訓(xùn)?
- 項(xiàng)目中最困難的部分是什么?如何解決團(tuán)隊(duì)開發(fā)時(shí)遇到的各種沖突?
面試題
Java常見的面試題已經(jīng)總結(jié)成《Java面試題集》、《Java面試題全集》以及《面試編程題拾遺》等文章陸續(xù)發(fā)布在我的CSDN博客,各大公司的面試題我會(huì)繼續(xù)整理發(fā)布。
其他
常見錯(cuò)誤
- 只在計(jì)算機(jī)上練習(xí)
- 不做行為面試題演練
- 不做模擬面試訓(xùn)練
- 試圖死記硬背答案
- 不大聲說出你的解題思路
- 代碼不夠嚴(yán)謹(jǐn)
- 不寫測(cè)試代碼
- 輕言放棄
面試時(shí)可以反問面試官的問題
- 我注意到你們使用了X技術(shù),請(qǐng)問你們是如何解決Y問題的?
- 為什么你們的產(chǎn)品使用了X技術(shù)而不是Y技術(shù)?據(jù)我所知,X技術(shù)雖然有A、B、C等好處,但也存在D和E問題,而Y技術(shù)可以解決D和E問題。
- 我對(duì)您說的X技術(shù)不是太熟悉,但我感覺它是一個(gè)不錯(cuò)的解決方案,您能多講講它的工作原理嗎?
- 你們團(tuán)隊(duì)是如何進(jìn)行項(xiàng)目規(guī)劃的?一周會(huì)有幾次例會(huì)?每周的代碼量大概是多少?
- 就X問題我能想到的解決方案目前就只有Y了,請(qǐng)問您會(huì)怎么解決這個(gè)問題?
STAR法則
STAR(Situation-Task-Action-Result)法則是指先描述問題的場(chǎng)景,然后解釋你需要完成的任務(wù),接下來是你采取的行動(dòng),最后陳述結(jié)果。通過STAR法則可以將技術(shù)的應(yīng)用場(chǎng)景以及多種技術(shù)在選型時(shí)的考慮都羅列出來,最終的結(jié)果就是對(duì)技術(shù)選型方案的一種驗(yàn)證。
算法題的五種解法
- 舉例法:通過舉例子發(fā)現(xiàn)其中的一般規(guī)則。
例子:圓內(nèi)接三角形是銳角三角形的概率是多少?這是搜狗的一個(gè)面試題,可以在圓上隨意畫三個(gè)點(diǎn)連接成三角形就可以知道答案了。
- 模式匹配法
例子:一個(gè)有序數(shù)組的元素經(jīng)過循環(huán)移動(dòng),元素的順序變成"3 4 5 6 1 2"。怎樣找到數(shù)組中最小的那個(gè)元素,假設(shè)數(shù)組中的元素各不相同。這個(gè)題目和折半查找看起來是那么相似,因此可以借鑒折半查找的算法,最小元素顯然出現(xiàn)在"mid > right"的轉(zhuǎn)折點(diǎn)。
- 簡(jiǎn)化推廣法
說明:簡(jiǎn)化問題規(guī)模和數(shù)據(jù)類型,然后再發(fā)現(xiàn)通用的解法。
- 簡(jiǎn)單構(gòu)造法
例子:找出"abcde"的所有可能的排列組合。先考慮只有"a"的情況,再考慮"ab"的情況,以此類推。最終你可能會(huì)得到一個(gè)遞歸公式。這種方法往往會(huì)演變成遞歸法。
- 數(shù)據(jù)結(jié)構(gòu)頭腦風(fēng)暴法
例子:隨機(jī)生成一些數(shù)字,并找出其中位數(shù)。這種問題可以在頭腦中將你了解的數(shù)據(jù)結(jié)構(gòu)過一遍,看看哪種是最合適的數(shù)據(jù)結(jié)構(gòu)。上面的題目可以建立兩個(gè)堆,一個(gè)大根堆和一個(gè)小根堆,較小的元素放在大根堆,較大的元素放在小根堆,如果兩個(gè)堆不平衡,可以從其中一個(gè)堆取出元素放入另一個(gè)堆即可。最后中位數(shù)應(yīng)該是兩個(gè)堆的根之一。
錄用談判
- 要理直氣壯的提出具體的待遇要求
- 開出比預(yù)期稍高的價(jià)碼
- 不要只盯著薪水(很多公司更愿意就薪水之外的條件做出讓步)
- 使用最合適的方法(可以嘗試在電話或E-mail中談判待遇)
自我評(píng)價(jià)
- 學(xué)習(xí)能力(搞IT行業(yè)的人需要不斷的了解新的技術(shù)、工具和方法)
- 團(tuán)隊(duì)意識(shí)(相比個(gè)人英雄主義,IT行業(yè)更倡導(dǎo)團(tuán)隊(duì)合作)
- 抗壓能力(很多IT企業(yè)的工作強(qiáng)度相對(duì)來說還是比較大的)