- 相關(guān)推薦
公司招聘面試試題
1、iBatis相比JDBC優(yōu)勢的優(yōu)勢有哪些?
答:簡單易上手、開發(fā)速度快、面向?qū)ο螅瑪?shù)據(jù)庫可移植。
(此處應(yīng)該將優(yōu)缺點一起分析,才是滿意得到回答)
延伸學(xué)習(xí):
MyBatis和iBatis的區(qū)別:
ibatis本是apache的一個開源項目,2010年這個項目由apache software foundation 遷移到了google code,并且改名為mybatis
(1)Mybatis實現(xiàn)了接口綁定,使用更加方便:
在ibatis2.x中我們需要在DAO的實現(xiàn)類中指定具體對應(yīng)哪個xml映射文件,而Mybatis實現(xiàn)了DAO接口與xml映射文件的綁定,
(2)對象關(guān)系映射的改進,效率更高
iBatis:
優(yōu)點 : 代碼量減少、簡單易上手、SQL語句和代碼分離(便于修改)、數(shù)據(jù)庫可移植
缺點:SQL語句需要自己寫、參數(shù)只能有一個
Hibernate:
優(yōu)點:對象關(guān)系數(shù)據(jù)庫映射、完全面向?qū)ο、提供緩存機制、HQL編程
缺點:不能靈活使用原生SQL、 無法對SQL優(yōu)化、全表映射效率低下、N+1的問題
JDBC、iBatis、Hibernate明顯對比:
JDBC更為靈活,更加有效率,系統(tǒng)運行速度快。但是代碼繁瑣復(fù)雜,有的時候用了存儲過程就不方便數(shù)據(jù)庫移植了。
hibernate,iBatis 關(guān)系數(shù)據(jù)庫框架,開發(fā)速度快,更加面向?qū)ο,可以移植更換數(shù)據(jù)庫,但影響系統(tǒng)性能。
JDBC:手動
手動寫sql,不能直接傳入一個對象、不能直接返回一個對象。
iBatis的特點:半自動化
手動寫sql,能直接傳入一個對象、能直接返回一個對象。
Hibernate:全自動
不寫sql,自動封裝,能直接傳入一個對象、能直接返回一個對象。
2、PrepareStatement相比statement,有哪些優(yōu)點?
答:(1)直接使用Statement,驅(qū)動程序一般不會對sql語句作處理而直接交給數(shù)據(jù)庫;
使用PreparedStament,形成預(yù)編譯的過程,并且會對語句作字符集的轉(zhuǎn)換(至少在sql server)中如此。
如此,有兩個好處:對于多次重復(fù)執(zhí)行的語句,使用PreparedStament效率會更高一點,并且在這種情況下也比較適合使用batch;另外,可以比較好地解決系統(tǒng)的本地化問題。
(2)PreparedStatement還能有效的防止危險字符的注入,也就是sql注入的問題。(但是必須使用“對?賦值的方法”才管用)
3、TCP/IP對應(yīng)于OSI七層模型的哪些層?
答:OSI七層模型分別是:應(yīng)用層、表示層、會話層、傳輸層、網(wǎng)絡(luò)層、數(shù)據(jù)鏈路層和物理層。
TCP/IP協(xié)議不是TCP和IP協(xié)議的合稱,而是指因特網(wǎng)整個TCP/IP協(xié)議族。從協(xié)議分層模型方面來看,TCP/IP由四個層次組成:網(wǎng)絡(luò)接口層、網(wǎng)絡(luò)層、傳輸層和應(yīng)用層。
4、為什么3次握手,4次揮手?
3次握手建立連接:
第一次握手:建立連接時,客戶端發(fā)送SYN包(syn=j)到服務(wù)器,并進入SYN_SENT狀態(tài),等待服務(wù)器確認;SYN:同步序列編號(Synchronize Sequence Numbers)即握手信號。
第二次握手:服務(wù)器收到SYN包,必須確認客戶的SYN(ack=j+1),同時自己也發(fā)送一個SYN包(syn=k),即SYN+ACK包,此時服務(wù)器進入SYN_RECV狀態(tài);
第三次握手:客戶端收到服務(wù)器的SYN+ACK包,向服務(wù)器發(fā)送確認包ACK(ack=k+1),此包發(fā)送完畢,客戶端和服務(wù)器進入ESTABLISHED(TCP連接成功)狀態(tài),完成三次握手。
4次揮手斷開連接:
對于一個已經(jīng)建立的連接,TCP使用改進的4次揮手來釋放連接(使用一個帶有FIN附加標記的報文段)。TCP關(guān)閉連接的步驟如下:
第一步,當(dāng)主機A的應(yīng)用程序通知TCP數(shù)據(jù)已經(jīng)發(fā)送完畢時,TCP向主機B發(fā)送一個帶有FIN附加標記的報文段(FIN表示英文finish)。
第二步,主機B收到這個FIN報文段之后,并不立即用FIN報文段回復(fù)主機A,而是先向主機A發(fā)送一個確認序號ACK,同時通知自己相應(yīng)的應(yīng)用程序:對方要求關(guān)閉連接(先發(fā)送ACK的目的是為了防止在這段時間內(nèi),對方重傳FIN報文段)。
第三步,主機B的應(yīng)用程序告訴TCP:我要徹底的關(guān)閉連接,TCP向主機A送一個FIN報文段。
第四步,主機A收到這個FIN報文段后,向主機B發(fā)送一個ACK表示連接徹底釋放。
5、進程和線程區(qū)別是什么?
答:進程是一個具有獨立功能的程序關(guān)于某個數(shù)據(jù)集合的一次運行活動。它可以申請和擁有系統(tǒng)資源,是一個動態(tài)的概念,是一個活動的實體。
進程是一個“執(zhí)行中的程序”。程序是一個沒有生命的實體,只有處理器賦予程序生命時,它才能成為一個活動的實體,我們稱其為進程。
一個進程中可以包含若干個線程,它們可以利用進程所擁有的資源。在引入線程的操作系統(tǒng)中,通常都是把進程作為分配資源的基本單位,而把線程作為獨立運行和獨立調(diào)度的基本單位。
線程與進程的區(qū)別歸納:
地址空間和其它資源:進程間相互獨立,同一進程的各線程間共享。某進程內(nèi)的線程在其它進程不可見。
通信:進程間通信IPC,線程間可以直接讀寫進程數(shù)據(jù)段(如全局變量)來進行通信——需要進程同步和互斥手段的輔助,以保證數(shù)據(jù)的一致性。
調(diào)度和切換:線程上下文切換比進程上下文切換要快得多。
【公司招聘面試試題】相關(guān)文章:
蘋果公司面試趣味試題09-25
德國公司經(jīng)典面試題11-10
NOKIA招聘筆試題09-26
公司招聘面試自我介紹05-25
2017搜狗招聘筆試題09-25
重慶煙草公司公考面試試題09-25
科技有限公司面試題目09-26
航空公司機務(wù)面試題09-29
2017幼教招聘筆試試題09-26