{eval=Array;=+count(Array);}
謝謝邀請(qǐng)!
作為一名從業(yè)多年的程序員,也出版過Java編程書籍,所以我來回答一下這個(gè)問題。
首先,對(duì)于剛學(xué)習(xí)完Java編程的準(zhǔn)程序員來說,從實(shí)習(xí)崗位開始做起是比較現(xiàn)實(shí)的選擇,一方面實(shí)習(xí)崗位不會(huì)有太大的工作壓力,另一方面也能夠積累大量的實(shí)踐經(jīng)驗(yàn)。
對(duì)于實(shí)習(xí)崗位的應(yīng)聘,主要的問題將集中在以下三個(gè)方面:
第一:Java的基本編程思想。Java編程思想的考察主要集中在對(duì)于“抽象”的理解,比如類、接口、抽象類分別用于哪些場(chǎng)景,各自的作用是什么等等。另外,面向?qū)ο蟮木幊踢^程、封裝、繼承、多態(tài)等都是面試當(dāng)中經(jīng)常會(huì)遇到的問題。一些大型軟件開發(fā)企業(yè)往往會(huì)在筆試中涉及到IO、多線程和網(wǎng)絡(luò)編程(Socket)知識(shí)。
第二:數(shù)據(jù)庫知識(shí)。數(shù)據(jù)庫知識(shí)通常是Java實(shí)習(xí)崗位考察的一個(gè)重點(diǎn),包括基本的Sql語句,數(shù)據(jù)庫部署等,另外需要掌握J(rèn)DBC知識(shí)。雖然目前通過DAO框架,比如MyBatis,可以完成數(shù)據(jù)庫映射(OO與OR),但是掌握J(rèn)DBC的細(xì)節(jié)還是有一定必要的。隨著大數(shù)據(jù)應(yīng)用的逐漸普及,未來Java程序員也需要掌握NoSql數(shù)據(jù)庫的相關(guān)技術(shù)。
第三:前端開發(fā)知識(shí)。雖然Java開發(fā)以后端開發(fā)為主,但是前端開發(fā)知識(shí)通常也會(huì)涉及到一些,不少開發(fā)團(tuán)隊(duì)還比較關(guān)注Java程序員的前端開發(fā)能力。前端開發(fā)知識(shí)主要涉及到Html、CSS和JavaScript,其中JavaScript是重點(diǎn)內(nèi)容,未來JavaScript將是程序員需要掌握的重要技能之一,因?yàn)槟壳癑avaScript的應(yīng)用邊界被不斷擴(kuò)展,從前端開發(fā)到后端開發(fā)(Nodejs)再到嵌入式開發(fā),都有JavaScript的身影。
最后,如果應(yīng)聘Web開發(fā)崗位,需要了解Spring框架知識(shí),如果面試大數(shù)據(jù)開發(fā)崗位,還需要了解Hadoop、Spark平臺(tái)知識(shí)。
我從事互聯(lián)網(wǎng)行業(yè)多年,目前也在帶計(jì)算機(jī)專業(yè)的研究生,主要的研究方向集中在大數(shù)據(jù)和人工智能領(lǐng)域,我會(huì)陸續(xù)寫一些關(guān)于互聯(lián)網(wǎng)技術(shù)方面的文章,感興趣的朋友可以關(guān)注我,相信一定會(huì)有所收獲。
如果有互聯(lián)網(wǎng)、大數(shù)據(jù)、人工智能等方面的問題,或者是考研方面的問題,都可以在評(píng)論區(qū)留言!
關(guān)于Java面試,一般應(yīng)該會(huì)問到下面這些問題。
[編程工具]
你常用的編程工具有哪些?這個(gè)問題主要是考察你工作的專業(yè)性,你是不是具有大型項(xiàng)目的工作經(jīng)驗(yàn).
一般好的,Java的編程工具,你比如說,Eclipse, netbeans, Intelli J 等等。
[局部變量和類變量的區(qū)別]
這個(gè)問題主要是考察選手對(duì)于scope的概念。回答這個(gè)問題,
就是局部變量是在方法里面定義的。這個(gè)變量只能在方法內(nèi)部才可以被調(diào)用。
類變量呢,可以在類的內(nèi)部,任何地方都可以被調(diào)用。類變量還可以添加一些修飾符,限制或者允許外部類調(diào)用。
[什么是繼承? ]
繼承就是說子類可以享有父類的一些定義。
[什么是封裝?]
封裝是通過類定義的方式,把一些方法和數(shù)據(jù)包裹起來。
[什么是多態(tài)?]
多態(tài)是指一個(gè)對(duì)象可以通過具體的引用類型來調(diào)用父類和子類的一些方法。
這三個(gè)問題主要是考察選手對(duì)于面向?qū)ο缶幊痰母拍睢?/p>
[ Overriding 和 overloading的區(qū)別]
這兩種方法在編程中會(huì)經(jīng)常用到。被問的可能性非常大。
Overriding主要用在子類要使用父類的一些方法定義。方法名必須相同,方法參數(shù)必須相同, 返回值類型必須相同。使用這種方法, 子類既可以調(diào)用父類的方法也可以添加自己個(gè)性化的實(shí)現(xiàn)。
Overloading主要用在方法這一層次上。具有同樣的方法名,不同的參數(shù)類型, 可能會(huì)返回不同的數(shù)據(jù)類型。
[接口和抽象的區(qū)別?]
這個(gè)問題在面向?qū)ο缶幊汤锩嬉彩墙?jīng)常被問到的一個(gè)問題。
在Java中,無法實(shí)現(xiàn)多類繼承,所以就引入了接口的概念。接口中,主要是類的聲明,沒有實(shí)現(xiàn)內(nèi)容。
抽象類中至少要含有一個(gè)抽象方法。這個(gè)抽象方法只有聲明沒有實(shí)現(xiàn)。抽象類的非抽象方法,需要有實(shí)現(xiàn)內(nèi)容。
[說一下訪問修飾符]
這也是面向?qū)ο缶幊汤锩娣浅V匾囊粋€(gè)概念。
private, protected, public。沒有修飾符,就是default。
private只能在本類內(nèi)部訪問。
protected在本類和子類中訪問。
public在其他類中都可訪問。
default在包內(nèi)可訪問。
[數(shù)組和數(shù)組列表的區(qū)別?]
[String, StringBuilder, StringBuffer的區(qū)別? ]
string不可修改。
string builder可修改,線程不安全的。
string buffer可修改,線程安全的。
[HashMap, HashTable 的區(qū)別? ]
都是字典類型。
hash map 是線程不安全的。
hash table 是線程安全的。
[Set 相關(guān)的問題]
Set里面的數(shù)據(jù)是唯一的。
sorted set是可排序的。
[Queue 相關(guān)的問題]
priority queue先進(jìn)先出。
[Map相關(guān)的問題]
有hash map, linked hash map, tree map.
[Tree相關(guān)的問題]
主要是二叉樹, 搜索二叉樹以及平衡二叉樹。
二叉樹是指只有左邊和右邊兩個(gè)節(jié)點(diǎn)的結(jié)構(gòu)。
搜索二叉樹是指左邊的節(jié)點(diǎn)永遠(yuǎn)比右邊的節(jié)點(diǎn)小。
平衡二叉樹是指左邊的高度與右邊的高度相差不超過1。
這是數(shù)據(jù)結(jié)構(gòu)相關(guān)的問題。
[final相關(guān)的問題]
final分別用在變量,類和方法上意味著什么。
final用在類上,這樣的類無法被繼承。
final用在變量上, 這樣的變量無法被修改。
final用在方法上,這樣的方法無法被overriding。
[Exception相關(guān)的問題]
一共有幾種exception?
out of index, io, illegal argument, etc.
他們的區(qū)別是什么?在什么時(shí)候用?
這樣的exception很多。顧名思義,在對(duì)應(yīng)的情況下使用對(duì)應(yīng)的exception。
Runtime exception和compile exception有什么區(qū)別?
run time exception,是在運(yùn)行過程中發(fā)生的exception。
compile exception,是指在程序編譯的時(shí)候,報(bào)出來的exception。
[線程相關(guān)的問題]
什么是線程?
線程是進(jìn)程的一個(gè)分支。
如何創(chuàng)建線程?
可以使用thread和 handler來創(chuàng)建線程。
如何在線程中間傳輸數(shù)據(jù)?
可以通過共享數(shù)據(jù)和線程變量。
解釋一下yield, wait, notify, notifyAll, sleep
yield是把線程從運(yùn)行狀態(tài),變?yōu)榭蛇\(yùn)行狀態(tài)。
wait是要求線程解鎖并放棄運(yùn)行狀態(tài),進(jìn)入等待隊(duì)列。
notify是用來從等待隊(duì)列里面喚醒一個(gè)線程。
notifyAll是用來從等待隊(duì)列里面喚醒所有線程。
sleep是暫停線程的執(zhí)行。當(dāng)前線程被喚醒后會(huì)進(jìn)入可運(yùn)行狀態(tài)。
解釋線程的生命狀態(tài)。
線程的生命狀態(tài),新創(chuàng)建,可運(yùn)行,正在運(yùn)行,不可運(yùn)行,終止。
如何實(shí)現(xiàn)線程的同步?線程同步有什么缺點(diǎn)?
通常使用synchronized 關(guān)鍵字來實(shí)現(xiàn)。缺點(diǎn)是降低了程序的執(zhí)行效率。
Volatile是干什么用的?
這個(gè)關(guān)鍵字是用來在主內(nèi)存上定義一個(gè)變量。而不是在線程的內(nèi)存上。主要用來做數(shù)據(jù)的共享。
[序列化是怎么回事]
序列化是指把一個(gè)對(duì)象寫入文件當(dāng)中。反序列化是指從文件返回一個(gè)對(duì)象。
如何來做序列化和反序列化?
可以使用objectoutputstream寫入和讀取。
好了,這個(gè)問題先說這些,歡迎關(guān)注丁哥開講,我們下次再見。
感謝邀請(qǐng)!
作為IT行業(yè)的一名Java開發(fā)人員,我可以給你一些建議。
實(shí)習(xí)生一般都是面試Java基礎(chǔ)崗,面試的問題一般都會(huì)隨著公司的大小有較大的區(qū)別。
一般大型公司。像BAT那樣的公司大部分都會(huì)很重視源碼這一方面。像一些集合的原理、鎖的底層原理都會(huì)重點(diǎn)去詢問,其次的話框架方面也會(huì)側(cè)重于底層原理的運(yùn)行。這方面網(wǎng)上會(huì)有很多 相關(guān)的面試題,你可以搜索完后做做。
中小型公司因?yàn)楣緲I(yè)務(wù)的需要,很多都會(huì)側(cè)重于應(yīng)用,比如sopringmvc框架的使用、集合的使用、map與list的區(qū)別等問題。很多的時(shí)候都會(huì)要求實(shí)習(xí)生介紹一下自己的項(xiàng)目,以及項(xiàng)目是如何去做的。數(shù)據(jù)庫的使用、jdbc等相關(guān)項(xiàng)目開發(fā)中用到的基礎(chǔ)都會(huì)去詢問。
推薦一個(gè)App“”牛客網(wǎng)“”,里面有很多練習(xí)題,可以模擬面試,應(yīng)該能滿足你的需求。
希望回答對(duì)您有所幫助。
我本人從事多年互聯(lián)網(wǎng)Java開發(fā),感興趣的朋友可以關(guān)注私聊,共同努力,共同進(jìn)步。
謝謝!
實(shí)習(xí)生面試java開發(fā)崗位,一般會(huì)問什么問題呢,下面是我整理的一些比較常見的面試題,希望能夠幫到小伙伴!
計(jì)算機(jī)網(wǎng)絡(luò)
1.TCP對(duì)應(yīng)的協(xié)議和UDP對(duì)應(yīng)的協(xié)議
TCP對(duì)應(yīng)的協(xié)議:
UDP對(duì)應(yīng)的協(xié)議:
2.簡(jiǎn)述IP地址的分類?
IP地址分為網(wǎng)絡(luò)號(hào)和主機(jī)號(hào), A類地址的前8位是網(wǎng)絡(luò)地址,B類地址的前16位是網(wǎng)絡(luò)地址,C 類地址的前24位是網(wǎng)絡(luò)地址。
A類地址: 1.0.0.0~126.0.0.0
B類地址:128.0.0.0 ~ 191.255.255.255
C類地址:192.0.0.0 ~ 223.255.255.255
D類地址:224.0.0.0 ~ 239.255.255.255 (作為多播使用)
E類地址:保留
A,B,C是基本類,D、E類作為多播和保留使用。主機(jī)號(hào),全0的是網(wǎng)絡(luò)號(hào),主機(jī)號(hào)全1的是廣播 地址。
3.HTTP協(xié)議包括哪些請(qǐng)求?
GET:對(duì)服務(wù)器資源的簡(jiǎn)單請(qǐng)求
POST:用于發(fā)送包含用戶提交數(shù)據(jù)的請(qǐng)求
HEAD:類似于GET請(qǐng)求,不過返回的響應(yīng)中沒有具體內(nèi)容,用于獲取報(bào)頭
PUT:傳說中請(qǐng)求文檔的一個(gè)版本
DELETE:發(fā)出一個(gè)刪除指定文檔的請(qǐng)求
TRACE:發(fā)送一個(gè)請(qǐng)求副本,以跟蹤其處理進(jìn)程
OPTIONS:返回所有可用的方法,檢查服務(wù)器支持哪些方法
CONNECT:用于ssl隧道的基于代理的請(qǐng)求
4.HTTP 原理
HTTP 是一個(gè)無狀態(tài)的協(xié)議。無狀態(tài)是指客戶機(jī)(Web 瀏覽器)和服務(wù)器之間不需要建立持久的連接,這意味著當(dāng)一個(gè)客戶端向服務(wù)器端發(fā)出請(qǐng)求,然后服務(wù)器返回響應(yīng)(response),連接就被關(guān)閉了,在服務(wù)器端不保留連接的有關(guān)信息.HTTP 遵循請(qǐng)求(Request)/應(yīng)答(Response)模型。客戶機(jī)(瀏覽器)向服務(wù)器發(fā)送請(qǐng)求,服務(wù)器處理請(qǐng)求并返回適當(dāng)?shù)膽?yīng)答。所有 HTTP 連接都被構(gòu)造成一套請(qǐng)求和應(yīng)答。
5.HTTPS
HTTPS(全稱:Hypertext Transfer Protocol over Secure Socket Layer),是以安全為目標(biāo)的HTTP 通道,簡(jiǎn)單講是 HTTP 的安全版。即 HTTP 下加入 SSL 層,HTTPS 的安全基礎(chǔ)是 SSL。其所用的端口號(hào)是 443。
java基礎(chǔ)
1.Java語言有哪些特點(diǎn)
封裝、繼承、多態(tài)、抽象。
2.什么是Java注釋
定義:用于解釋說明程序的文字
Java注釋的分類
單行注釋 格式:
Java注釋的作用
在程序中,尤其是復(fù)雜的程序中,適當(dāng)?shù)丶尤胱⑨尶梢栽黾映绦虻目勺x性,有利于程序的修 改、調(diào)試和交流。注釋的內(nèi)容在程序編譯的時(shí)候會(huì)被忽視,不會(huì)產(chǎn)生目標(biāo)代碼,注釋的部分不 會(huì)對(duì)程序的執(zhí)行結(jié)果產(chǎn)生任何影響。
注意事項(xiàng):多行和文檔注釋都不能嵌套使用。
3.Java有哪些數(shù)據(jù)類型
定義:Java語言是強(qiáng)類型語言,對(duì)于每一種數(shù)據(jù)都定義了明確的具體的數(shù)據(jù)類型,在內(nèi)存中分 配了不同大小的內(nèi)存空間。
基本數(shù)據(jù)類型
引用數(shù)據(jù)類型
4.Java中實(shí)現(xiàn)多態(tài)的機(jī)制是什么?
Java中的多態(tài)靠的是父類或接口定義的引用變量可以指向子類或具體實(shí)現(xiàn)類的實(shí)例對(duì)象,而程 序調(diào)用的方法在運(yùn)行期才動(dòng)態(tài)綁定,就是引用變量所指向的具體實(shí)例對(duì)象的方法,也就是內(nèi)存 里正在運(yùn)行的那個(gè)對(duì)象的方法,而不是引用變量的類型中定義的方法。
5.String類的常用方法有哪些?
數(shù)據(jù)庫
1.數(shù)據(jù)庫事務(wù)
事務(wù)(TRANSACTION)是作為單個(gè)邏輯工作單元執(zhí)行的一系列操作,這些操作作為一個(gè)整體一起向系統(tǒng)提交,要么都執(zhí)行、要么都不執(zhí)行 。事務(wù)是一個(gè)不可分割的工作邏輯單元。
2.存儲(chǔ)過程(特定功能的 SQL 語句集)
一組為了完成特定功能的 SQL 語句集,存儲(chǔ)在數(shù)據(jù)庫中,經(jīng)過第一次編譯后再次調(diào)用不需要再次編譯,用戶通過指定存儲(chǔ)過程的名字并給出參數(shù)(如果該存儲(chǔ)過程帶有參數(shù))來執(zhí)行它。存儲(chǔ)過程是數(shù)據(jù)庫中的一個(gè)重要對(duì)象。
3.基于 Redis 分布式鎖
4.MySQL 數(shù)據(jù)庫服務(wù)器性能分析的方法命令有哪些?
Show status 一些值得監(jiān)控的變量值: Bytesreceived 和 Bytessent 和服務(wù)器之間來往的流量。 Com 服務(wù)器正在執(zhí)行的命令。 Created 在查詢執(zhí)行期限間創(chuàng)建的臨時(shí)表和文件。 Handler 存儲(chǔ)引擎操作。 Select 不同類型的聯(lián)接執(zhí)行計(jì)劃。 Sort_* 幾種排序信息。
Show session status like ‘Select’; Show profiles SET profiling=1; Show profilesG Show profile;
5.Redis 實(shí)現(xiàn)原理或機(jī)制
Redis 是一個(gè) key-value 存儲(chǔ)系統(tǒng)。和 Memcached 類似,但是解決了斷電后數(shù)據(jù)完全丟失的情況,而且她支持更多無化的 value 類型,除了和 string 外,還支持lists(鏈表)、sets(集合)和 zsets(有序集合)幾種數(shù)據(jù)類型。這些數(shù)據(jù)類型都支持 push/pop、add/remove 及取交集并集和差集及更豐富的操作,而且這些操作都是原子性的。
Redis 是一種基于客戶端 – 服務(wù)端模型以及請(qǐng)求 / 響應(yīng)協(xié)議的 TCP 服務(wù)。這意味著通常情況下一個(gè)請(qǐng)求會(huì)遵循以下步驟:
客戶端向服務(wù)端發(fā)送一個(gè)查詢請(qǐng)求,并監(jiān)聽 Socket 返回,通常是以阻塞模式,等待服務(wù)端響應(yīng)。服務(wù)端處理命令,并將結(jié)果返回給客戶端。
在服務(wù)端未響應(yīng)時(shí),客戶端可以繼續(xù)向服務(wù)端發(fā)送請(qǐng)求,并最終一次性讀取所有服務(wù)端的響應(yīng)。
Redis 管道技術(shù)最顯著的優(yōu)勢(shì)是提高了 Redis 服務(wù)的性能。
分區(qū)是分割數(shù)據(jù)到多個(gè) Redis 實(shí)例的處理過程,因此每個(gè)實(shí)例只保存 key 的一個(gè)子集。
通過利用多臺(tái)計(jì)算機(jī)內(nèi)存的和值,允許我們構(gòu)造更大的數(shù)據(jù)庫。
通過多核和多臺(tái)計(jì)算機(jī),允許我們擴(kuò)展計(jì)算能力;通過多臺(tái)計(jì)算機(jī)和網(wǎng)絡(luò)適配器,允許我們擴(kuò)展網(wǎng)絡(luò)帶寬。
Redis 的一些特性在分區(qū)方面表現(xiàn)的不是很好:
涉及多個(gè) key 的操作通常是不被支持的。舉例來說,當(dāng)兩個(gè) set 映射到不同的Redis 實(shí)例上時(shí),你就不能對(duì)這兩個(gè) set 執(zhí)行交集操作。
涉及多個(gè) key 的 Redis 事務(wù)不能使用。
當(dāng)使用分區(qū)時(shí),數(shù)據(jù)處理較為復(fù)雜,比如你需要處理多個(gè) rdb/aof 文件,并且從多個(gè)實(shí)例和主機(jī)備份持久化文件。
增加或刪除容量也比較復(fù)雜。Redis 集群大多數(shù)支持在運(yùn)行時(shí)增加、刪除節(jié)點(diǎn)的透明數(shù)據(jù)平衡的能力,但是類似于客戶端分區(qū)、代理等其他系統(tǒng)則不支持這項(xiàng)特性。然而,一種叫做 presharding 的技術(shù)對(duì)此是有幫助的。
以上是我整理的關(guān)于java面試的一些問題,可能不全,希望小伙伴根據(jù)自己所學(xué)習(xí)的基本情況加以彌補(bǔ)。
java開發(fā)技術(shù)學(xué)習(xí)教程及學(xué)習(xí)路線
http://www.atguigu.com/download.shtml
H5全棧前端開發(fā)技術(shù)學(xué)習(xí)教程及學(xué)習(xí)路線
http://www.atguigu.com/html5_video.shtml
大數(shù)據(jù)開發(fā)技術(shù)學(xué)習(xí)教程及學(xué)習(xí)路線
http://www.atguigu.com/bigdata_video.shtml
0
回答0
回答0
回答0
回答0
回答0
回答0
回答0
回答0
回答0
回答