不卡AV在线|网页在线观看无码高清|亚洲国产亚洲国产|国产伦精品一区二区三区免费视频

學(xué)習(xí)啦 > 創(chuàng)業(yè)指南 > 職場(chǎng) > 面試題 > 2017java筆試面試題及參考答案

2017java筆試面試題及參考答案

時(shí)間: 如英753 分享

2017java筆試面試題及參考答案

  做筆試面試題幾乎是每個(gè)公司選拔java個(gè)人求職者的必要程序,對(duì)java個(gè)人求職者是一種考核形式。下面是學(xué)習(xí)啦小編為大家?guī)?lái)的2017 java筆試面試題,相信對(duì)你會(huì)有幫助的。

  2017java筆試面試題

  一.選擇題(30分)

  1.下列哪些情況可以終止當(dāng)前線程的運(yùn)行?

  a. 拋出一個(gè)異常時(shí)。

  b. 當(dāng)該線程調(diào)用sleep()方法時(shí)。

  c. 當(dāng)創(chuàng)建一個(gè)新線程時(shí)。(與當(dāng)前進(jìn)程無(wú)關(guān))

  d. 當(dāng)一個(gè)優(yōu)先級(jí)高的線程進(jìn)入就緒狀態(tài)時(shí)。

  2. 下面哪些為構(gòu)造函數(shù)的特性定義

  a. 在類中聲明構(gòu)造函數(shù)時(shí),名稱應(yīng)該與類名相同

  b. 具有重載特性,可以建立多個(gè)相同的名稱

  c. 使用類建立新對(duì)象時(shí),會(huì)自動(dòng)執(zhí)行構(gòu)造函數(shù),因此在構(gòu)造函

  數(shù)內(nèi)設(shè)定變量的初值或進(jìn)行內(nèi)存分配

  d. 以上都是

  3. 關(guān)于異常處理機(jī)制的敘述哪些正確

  a. catch部分捕捉到異常情況時(shí),才會(huì)執(zhí)行finally部分(無(wú)論是否有毛病,都執(zhí)行)

  b. 當(dāng)try區(qū)段的程序發(fā)生異常時(shí),才會(huì)執(zhí)行catch區(qū)段的程序

  c. 不論程序是否發(fā)生錯(cuò)誤及捕捉到異常情況,都會(huì)執(zhí)行finally部分

  d. 以上都是

  4. 下列關(guān)于接口的敘述中哪些是正確的

  a. 接口中的數(shù)據(jù)必須設(shè)定初值(就是接口中的常量)

  b. 接口中的方法都是抽象方法

  c. 接口可以聲明引用

  d. 以上都正確

  5. Java語(yǔ)言中,方法的重寫(xiě)(Overriding)和重載(Overloading)是多態(tài)性的不同表現(xiàn)。下邊哪些說(shuō)法是對(duì)的?

  A. 重寫(xiě)是父類與子類之間多態(tài)性的一種表現(xiàn)。

  B. 重寫(xiě)是一個(gè)類中多態(tài)性的一種表現(xiàn)。

  C. 重載是一個(gè)類中多態(tài)性的一種表現(xiàn)。

  D. 重載是父類與子類之間多態(tài)性的一種表現(xiàn)。

  6.在Struts應(yīng)用的視圖中包含哪些組件?

  A. JSP

  B. Servlet

  C. ActionServlet

  D. Action

  E. 代表業(yè)務(wù)邏輯或業(yè)務(wù)數(shù)據(jù)的JavaBean

  F. EJB

  G. 客戶化標(biāo)簽

  7. struts框架中,關(guān)于FormBean,下列哪些說(shuō)法是正確的:

  A FormBean是一種數(shù)據(jù)bean,主要用來(lái)封裝表單提交上來(lái)的數(shù)據(jù),并把這些數(shù)據(jù)傳遞給Action

  B 在FormBean中可以對(duì)頁(yè)面上傳遞來(lái)的參數(shù)進(jìn)行一下格式上的驗(yàn)證,這種驗(yàn)證是一種客戶端的驗(yàn)證

  C 用戶每次提交表單,都會(huì)產(chǎn)生一個(gè)新的FormBean實(shí)例

  D 動(dòng)態(tài)FormBean不能進(jìn)行驗(yàn)證操作

  8哪些方法可以進(jìn)行servlet的調(diào)試?()

  A、使用打印語(yǔ)句; 在桌面計(jì)算機(jī)上運(yùn)行服務(wù)器

  B、使用Apache Log4J

  C、使用IDE集成的調(diào)試器

  D、直接查看HTML源碼 ????

  E、返回錯(cuò)誤頁(yè)面給客戶

  9、下面關(guān)于servlet的功用說(shuō)法正確的有哪些?()

  A、讀取客戶程序發(fā)送來(lái)的顯式數(shù)據(jù)

  B、讀取客戶程序發(fā)送來(lái)的隱式數(shù)據(jù)

  C、生成相應(yīng)的結(jié)果

  D、發(fā)送顯式的數(shù)據(jù)給客戶程序

  E、發(fā)送隱式的數(shù)據(jù)給客戶程序

  10、下面關(guān)于session的用法哪些是錯(cuò)誤的?(

  A、HttpSession session = new HttpSession();

  request.getSession();

  B、String haha =(String) session.getParameter(Attribute)(“haha”);

  C、session.removeAttribute(“haha”);

  D、session. setAttribute(“haha”,值);

  11、關(guān)于說(shuō)法正確的有哪些?()

  A、URL的輸出在請(qǐng)求時(shí)被插入到JSP頁(yè)面中

  B、不能含有影響整個(gè)頁(yè)面的JSP內(nèi)容

  C、被包含文件改變后不需更改使用它的頁(yè)面

  D、被包含文件更改后,需要手動(dòng)地更新使用它的頁(yè)面(不需要手動(dòng)更新)

  12、關(guān)于bean的說(shuō)法正確的有哪些?()

  A、具備一個(gè)零參數(shù)(空)的構(gòu)造函數(shù)(不是必須的)

  B、不應(yīng)該有公開(kāi)的實(shí)例變量(字段)

  C、所有的屬性都必須通過(guò)getXxx和setXxx方法來(lái)訪問(wèn)

  D、布爾型的屬性使用isXxx,而非getXxx

  13、下面關(guān)于MVC說(shuō)法錯(cuò)誤的有哪些?()

  A、必須使用復(fù)雜的框架

  B、使用內(nèi)建的RequestDispatcher能夠很好地實(shí)現(xiàn)MVC

  C、當(dāng)其中一個(gè)組件發(fā)生變化的時(shí)候,MVC影響整個(gè)系統(tǒng)的設(shè)計(jì)

  D、我們可以用MVC來(lái)處理單個(gè)請(qǐng)求

  14、下面的標(biāo)簽中哪些是JSTL標(biāo)簽?()

  15、struts框架,錯(cuò)誤的是,下面那些說(shuō)法正確?

  A Struts中無(wú)法完成上傳功能

  B Struts框架基于MVC模式

  C Struts框架容易引起流程復(fù)雜、結(jié)構(gòu)不清晰等問(wèn)題(清晰)

  D Struts可以有效地降低項(xiàng)目的類文件數(shù)目

  二、填空題( 5分)

  1、調(diào)用函數(shù)MOD(123,10)返回值為_(kāi)__。

  2、select round (123.67,1) from dual;這語(yǔ)句輸出值為_(kāi)_____。

  3、創(chuàng)建一個(gè)臨時(shí)替代變量使用的字符是_____。

  4、若v_comm = 2800, X := NVL (V_comm,0) ,則X的值為_(kāi)___。

  5、調(diào)用函數(shù)INSTR(‘Here you are’,’er’)返回值為_(kāi)__。

  三、判斷題(10分)

  1、WHERE子句限制行記錄,也可以指定限制分組結(jié)果的條件。 ()

  2、具有UNIQUE約束的列不能包含多個(gè)空值。 ()

  3、DATE型數(shù)據(jù)中包含著時(shí)間值。 ()

  4、具有外鍵約束的列可以包含空值。 ()

  5、如果在類型為char(4)的列中輸入“hello”,則只能存儲(chǔ)hell。 ()

  6、含有Group by子句的查詢,其結(jié)果是排好序的。 ()

  7、定義游標(biāo)時(shí),其中的select語(yǔ)句不能使用order by子句。(子查詢

  不能用) ()

  9、觸發(fā)器一定會(huì)被激發(fā)。 、過(guò)程可以有返回值。 ()

  10、instead

  of觸發(fā)器只是基于視圖的。

  四、寫(xiě)出相應(yīng)的SQL語(yǔ)句(括號(hào)內(nèi)為列名)(10分)

  1、查詢從事各工作(JOB)的員工人數(shù)。

  2、查詢與員工SMITH在同一部門(DEPTNO)的員工的姓名(ENAME),工資(SAL)和部門。

  3、查詢所有員工的姓名(ENAME),工資(SAL)和工資等級(jí)(GRADE)。

  4、查詢獲得工資(SAL)最高的3個(gè)員工信息。

  5、查詢所有員工的姓名(ENAME)及其主管姓名(ENAME)。

  五、簡(jiǎn)答題(15分)

  1. 在PL/SQL程序中,進(jìn)行用戶自定義異常處理的3個(gè)步驟是

  什么?

  2. 面向?qū)ο蟮奶卣饔心男┓矫?并簡(jiǎn)要介紹

  3. List、Map、Set三個(gè)接口,存取元素時(shí),各有什么特點(diǎn)?

  List 以特定次序來(lái)持有元素,可有重復(fù)元素。Set 無(wú)法擁有重復(fù)元素,內(nèi)部排序。Map 保存key-value值,value可多值。

  4 .struts1.0和struts2.0的區(qū)別?如何控制兩種框架中的單例模式?

  5. 描述一下如何在struts1.0實(shí)現(xiàn)國(guó)際化,以兩國(guó)語(yǔ)言(中文,英文)為例:

  6.struts中怎么配置form-bean、action

  7. Hibernate自帶的分頁(yè)機(jī)制是什么?如果不使用Hibernate自帶的分頁(yè),則采用什么方式分頁(yè)?

  8. hibernate中一對(duì)多配置文件返回的是什么?

  9.什么樣的數(shù)據(jù)適合存放到第二級(jí)緩存中?

  10你一般用spring做什么?

  11項(xiàng)目中如何體現(xiàn)Spring中的切面編程,具體說(shuō)明。

  12 觸發(fā)觸發(fā)器的數(shù)據(jù)操作有哪些?

  13 解釋視圖的含義以及使用視圖的好處。

  14 簡(jiǎn)述ORACLE中5種約束及其作用。

  15 ORACLE中過(guò)程和函數(shù)的異同點(diǎn)。

  六、編程題(30分)

  1、創(chuàng)建一個(gè)PL/SQL塊,根據(jù)用戶輸入的編號(hào),在emp表中查詢出該編號(hào)的員工姓名、部門號(hào)及其主管編號(hào),要有異常處理。

  2、創(chuàng)建一個(gè)PL/SQL塊,根據(jù)用戶輸入的工作,從emp表中逐條輸出從事這一工作的每位員工的編號(hào)、姓名和受雇如期,每條信息格式如下:(用游標(biāo)實(shí)現(xiàn))

  編號(hào) 姓名 受雇日期

  7751 JOHN 95-12-31

  3、編寫(xiě)一個(gè)函數(shù),用于判斷EMP表中某一工作(JOB)是否存在,若EMP表存在此工作名稱,則返回TRUE,否則返回FALSE。

  4、編寫(xiě)一觸發(fā)器,在EMP表執(zhí)行插入或修改前被激發(fā),此觸發(fā)器將對(duì)員工的工資(SAL)超過(guò)5000進(jìn)行報(bào)錯(cuò),不能插入或修改,不超

  過(guò)5000的才將員工編號(hào)、工作及當(dāng)時(shí)的日期(SYSDATE)插入U(xiǎn)P_EMP表

  (注:此表已建好,表結(jié)構(gòu)為UP_EMP(EMPNO NUMBER(4),SAL NUMBER(7,2),UDETE DATE))

  5下面程序的輸出結(jié)果是多少?

  import java.util.Date;

  public class Test extends Date{

  public static void main(String[] args) {

  new Test().test();}

  public void test(){

  System.out.println(super.getClass().getName());}}

  6下面的程序代碼輸出的結(jié)果是多少? public class smallT

  {}

  public static void main(String args[]) { } public int get() { } try { } finally { } return 2 ; return 1 ; smallT t = new smallT(); int b = t.get(); System.out.println(b);

  7子線程循環(huán)10次,接著主線程循環(huán)100,接著又回到子線程循環(huán)10次,接著再回到主線程又循環(huán)100,如此循環(huán)50次,請(qǐng)寫(xiě)出程序。

  8去掉一個(gè)Vector集合中重復(fù)的元素

  9有一個(gè)字符串,其中包含中文字符、英文字符和數(shù)字字符,請(qǐng)統(tǒng)計(jì)和打印出各個(gè)字符的個(gè)數(shù)

  10. xxx公司的sql面試

  Table EMPLOYEES Structure:

  EMPLOYEE_ID NUMBER Primary Key,

  FIRST_NAME VARCHAR2(25),

  LAST_NAME VARCHAR2(25),

  Salary number(8,2),

  HiredDate DATE,

  Departmentid number(2)

  Table Departments Structure:

  Departmentid number(2) Primary Key,

  DepartmentName VARCHAR2(25).

  (1)基于上述EMPLOYEES表寫(xiě)出查詢:寫(xiě)出雇用日期在今年的,或者工資在[1000,2000]之間的,或者員工姓名(last_name)以’Obama’打頭的所有員工,列出這些員工的全部個(gè)人信息。

  (2) 基于上述EMPLOYEES表寫(xiě)出查詢:查出部門平均工資大于1800

  元的部門的所有員工,列出這些員工的全部個(gè)人信息。()

  (3) 基于上述EMPLOYEES表寫(xiě)出查詢:查出個(gè)人工資高于其所在部門平均工資的員工,列出這些員工的全部個(gè)人信息及該員工工資高出部門平均工資百分比。

  2017java筆試面試題參考答案

  1答案:ABD

  2答案: D

  3答案:BC

  4答案:AB

  5答案AC

  6答案:A,G

  7答案:A

  8A B C D E

  9A B C D E

  10A B D

  11A B C

  12B D

  13A C

  14A B C

  15A B C

  16答案:C

  二 填空

  3 123.7 & 2800 2

  三判斷

  × ×√√√√×√×√

  四寫(xiě)出相應(yīng)的SQL語(yǔ)句

  1Select job,count(*) from emp group by job;

  2Select ename,sal,deptno from emp where deptno=(select deptno from emp where ename=’SMITH’);

  3Select ename,sal,grade from emp,salgrade where sal between losal and hisal;

  4Select * from (select * from emp order by sal desc) where rownum<=3;

  5Select e1.ename empname,e2.ename mgrname from emp e1,emp e2 where e1.mgr=e2.empno;

  五簡(jiǎn)答

  可以通過(guò)聲明和發(fā)布來(lái)截獲自定義異常。

  一、在聲明部分為聲明自定義異常名。

  二、在執(zhí)行部分使用 RAISE 語(yǔ)句顯式地發(fā)布異常。

  三、在相應(yīng)的異常處理例程中引用已聲明的異常。

  2(1).抽象:

  抽象就是忽略一個(gè)主題中與當(dāng)前目標(biāo)無(wú)關(guān)的那些方面,以便更充分地注意與當(dāng)前目標(biāo)有關(guān)的方面。抽象并不打算了解全部問(wèn)題,而只是選擇其中的一部分,暫時(shí)不用部分細(xì)節(jié)。抽象包括兩個(gè)方面,一是過(guò)程抽象,二是數(shù)據(jù)抽象。

  (2).繼承:

  繼承是一種聯(lián)結(jié)類的層次模型,并且允許和鼓勵(lì)類的重用,它提供了一種明確表述共性的方法。對(duì)象的一個(gè)新類可以從現(xiàn)有的類中派生,這個(gè)過(guò)程稱為類繼承。新類繼承了原始類的特性, 新類稱為原始類的派生類(子類),而原始類稱為新類的基類(父類)。派生類可以從它的基類那里繼承方法和實(shí)例變量,并且類可以修改或增加新的方法使之更適合特殊的需要。

  (3).封裝:

  封裝是把過(guò)程和數(shù)據(jù)包圍起來(lái),對(duì)數(shù)據(jù)的訪問(wèn)只能通過(guò)已定義的界面。面向?qū)ο笥?jì)算始于這個(gè)基本概念,即現(xiàn)實(shí)世界可以被描繪成一系列完全自治、封裝的對(duì)象,這些對(duì)象通過(guò)一個(gè)受保護(hù)的接口訪問(wèn)其他對(duì)象。

  (4). 多態(tài)性:

  多態(tài)性是指允許不同類的對(duì)象對(duì)同一消息作出響應(yīng)。多態(tài)性包括參數(shù)化多態(tài)性和包含多態(tài)性。多態(tài)性語(yǔ)言具有靈活、抽象、行為共享、代碼共享的優(yōu)勢(shì),很好的解決了應(yīng)用程序函數(shù)同名問(wèn)題。

  List 以特定次序來(lái)持有元素,可有重復(fù)元素。Set 無(wú)法擁有重復(fù)元素,內(nèi)部排序。Map 保存key-value值,value可多值。

  3List 以特定次序來(lái)持有元素,可有重復(fù)元素。Set 無(wú)法擁有重復(fù)元素,內(nèi)部排序。Map 保存key-value值,value可多值

  4a、Action類:

  struts1.2要求Action類繼承一個(gè)基類。struts2.0 Action要求繼承ActionSupport基類 b、線程模式

  struts1.2 Action是單例模式的并且必須是線程安全的,因?yàn)閮H有一個(gè)Action的實(shí)例來(lái)處理所有的請(qǐng)求。

  單例策略限制了Struts1.2 Action能做的事情,并且開(kāi)發(fā)時(shí)特別小心。Action資源必須是線程安全的或同步的。

  struts2.0 Action為每一個(gè)請(qǐng)求產(chǎn)生一個(gè)實(shí)例,因此沒(méi)有線程安全問(wèn)題。

  c、Servlet依賴

  struts1.2 Action依賴于Servlet API,因?yàn)楫?dāng)一個(gè)Action被調(diào)用時(shí)HttpServletRequest和HttpServletResponse被傳遞給execut方法。

  struts2.0 Action不依賴于容器,允許Action脫離容器單獨(dú)測(cè)試。如果需要,Struts2 Action仍

  然可以訪問(wèn)初始的Request和Response。

  但是,其他的元素減少或者消除了直接訪問(wèn)HttpServletRequest和HttpServletResponse的必要性。

  d、可測(cè)性

  測(cè)試struts1.2 Action的一個(gè)主要問(wèn)題是execute方法暴露了Servlet API(這使得測(cè)試要依賴于容器)。一個(gè)第三方擴(kuò)展:struts TestCase

  提供了一套struts1.2的模擬對(duì)象來(lái)進(jìn)行測(cè)試。

  Struts2.0 Action可以通過(guò)初始化、設(shè)置屬性、調(diào)用方法來(lái)測(cè)試,“依賴注入”也使得測(cè)試更容易。

點(diǎn)擊下頁(yè)還有更多>>>2017java筆試面試題參考答案

1081914