更新時(shí)間:2020-05-29 15:48:45 來源:動(dòng)力節(jié)點(diǎn) 瀏覽5805次
作為技術(shù)出身的我們,找工作的一大前提就是技術(shù)是否能過關(guān)。而對于Java程序員來說,至少是兩關(guān)的面試,這首個(gè)關(guān)卡就是筆試,今天小編總結(jié)了一些關(guān)于Java的面試題,希望能幫助到正在求職的你!
1、Java的數(shù)據(jù)結(jié)構(gòu)你用過哪些?map與set的本質(zhì)區(qū)別是什么
數(shù)據(jù)結(jié)構(gòu):是指相互之間存在一種或多種特定關(guān)系的數(shù)據(jù)元素的集合。
依據(jù)邏輯關(guān)系,數(shù)據(jù)結(jié)構(gòu)分為:線性和非線性數(shù)據(jù)結(jié)構(gòu)。
2、Map與Set的本質(zhì)區(qū)別是什么?
Set不能包含重復(fù)的元素,zui多有一個(gè)空值,繼承自Collection接口,底層是Map實(shí)現(xiàn)機(jī)制。Map不能包含重復(fù)的鍵,每個(gè)鍵zui多對應(yīng)一個(gè)映射的值,不能有空值鍵。兩接口提供的方法不完全一樣。
3、Java常見的數(shù)據(jù)結(jié)構(gòu)有哪些?
Java常見的數(shù)據(jù)結(jié)構(gòu)有Collection和Map,其中Collection接口下包括List和Set接口,其下又有多個(gè)實(shí)現(xiàn)類如List下有ArrayList、LinkedList和Vector等實(shí)現(xiàn)類,Set下有HashSet、LinkedSet等實(shí)現(xiàn)類和SortedSet接口,HashSet下有LinkedHashSet子類,SortedSet接口下有TreeSet實(shí)現(xiàn)類。Map接口下有HashMap(有LinkedHashMap子類)、HashTable(有Properties子類)實(shí)現(xiàn)類和SortedMap接口(有TreeMap實(shí)現(xiàn)類)。
Java的數(shù)據(jù)結(jié)構(gòu)主要有List、Set、Map、ArrayList、HashSet、HashMap、Properties等。
4、Java中的Annotation的工作原理是什么
一個(gè)annotation類型被定義為runtime retention后,它才是在運(yùn)行時(shí)可見,當(dāng)class文件被裝載時(shí)被保存在class文件中的annotation才會(huì)被虛擬機(jī)讀取。
Annotation提供一種機(jī)制,將程序的元素如:類,方法,屬性,參數(shù),本地變量,包和元數(shù)據(jù)聯(lián)系起來。這樣編譯器可以將元數(shù)據(jù)存儲在Class文件中。這樣虛擬機(jī)和其它對象可以根據(jù)這些元數(shù)據(jù)來決定如何使用這些程序元素或改變它們的行為。
5、分層架構(gòu)中,Dao層的作用是什么?如果不要Dao層,能不能實(shí)現(xiàn)Dao層時(shí)的優(yōu)點(diǎn)
Dao層又叫數(shù)據(jù)訪問對象層,封裝數(shù)據(jù)庫的底層操作細(xì)節(jié)如數(shù)據(jù)庫的連接及對數(shù)據(jù)的CRUD等操作,它不但屏蔽了數(shù)據(jù)存儲最終介質(zhì)的不同,也屏蔽了具體實(shí)現(xiàn)技術(shù)的不同。一般在其上還會(huì)有Service層來封裝業(yè)務(wù)操作進(jìn)行進(jìn)一步的解耦。不用DAO層也能實(shí)現(xiàn)Dao層時(shí)的優(yōu)點(diǎn)如自己封裝一個(gè)類似Dao層功能的數(shù)據(jù)庫操作模板類,可參考Spring的DAO層思想。
以上就是動(dòng)力節(jié)點(diǎn)java培訓(xùn)機(jī)構(gòu)的小編針對“2020年最新經(jīng)典Java筆試題庫及答案”的內(nèi)容進(jìn)行的回答,希望對大家有所幫助,如有疑問,請?jiān)诰€咨詢,有專業(yè)老師隨時(shí)為你服務(wù)。
相關(guān)閱讀
初級 202925
初級 203221
初級 202629
初級 203743