- 相關(guān)推薦
Java軟件開(kāi)發(fā)工程師筆試題
下面CN人才網(wǎng)小編為大家?guī)?lái)的是Java軟件開(kāi)發(fā)工程師筆試題,希望對(duì)大家有所幫助~
一、選擇題(本大題 20 小題,每小題2分.共40分)。
1.在JAVA中,如果父類(lèi)中某些方法不包含任何邏輯,并且需要由子類(lèi)重寫(xiě).應(yīng)該使用( )關(guān)鍵字來(lái)聲明父類(lèi)的這些方法:
A) final B) static C) abstract D) void
2.在JAVA中,已定義兩個(gè)接口B和C,要定義一個(gè)實(shí)現(xiàn)這兩個(gè)接口的類(lèi),以下語(yǔ)句正確的是( )。
A) interface A extend B,C B) interface A implements B,C
C) class A implements B,C D) class A implements B, implements C
3.在JAVA接口中可以定義( )。
A) 靜態(tài)方法 B) 常量 C) 構(gòu)造方法 D) 抽象方法
4.假設(shè)A有構(gòu)造方法A (int a),則在類(lèi)A的其他構(gòu)造方法中調(diào)用該構(gòu)造方法和語(yǔ)句格式應(yīng)為( )。
A) A(X) B) this.A(x) C) this(x) D) super(x)
5.設(shè) x = 1 ,y = 2 , z = 3, 則表達(dá)式 y+=z--/++x 的值是( )。
A) 3 B) 3.5 C) 4 D) 5
6.下列關(guān)于繼承的說(shuō)法哪個(gè)正確?( )。
A)子類(lèi)只繼承父類(lèi)public方法和屬性:
B)子類(lèi)繼承父類(lèi)的非私有屬性和方法:
C)子類(lèi)繼承父類(lèi)的方法,而不繼承父類(lèi)的屬性:
D) 子類(lèi)將繼承的所有的屬性和方法.
7.在java中.在使用JDBC時(shí)。對(duì)于多次調(diào)用同一條SQL語(yǔ)句的情況, 使用( )通常會(huì)提高效。
A) Statement B) CallableStatement
C) PreparedStatement D) PrarmeterStatement
8.下列不能控制一個(gè)Servlet的生命周期方的法是:
A) service B) destroy C) doPost D) init
9.能夠給一個(gè)byte型變量賦值的范圍是( )。
A) 0~65535 B) (-128)~127
C)(-32, 768)~32, 767 D) (-256)~255
10.java語(yǔ)言中int類(lèi)型數(shù)據(jù)占用多少位?( )。
A) 32 B) 64 C) 16 D) 20
11. ServletContext對(duì)象是如何創(chuàng)建的?( )。
A) 由 Servlet容器創(chuàng)建,對(duì)于每個(gè)HTTP請(qǐng)求.Servlet容器都會(huì)創(chuàng)建 一個(gè)ServletContext對(duì)象
B)由JavaWeb 應(yīng)用本身為自己創(chuàng)建一個(gè)ServletContext對(duì)象
C)由Servlet容器創(chuàng)建,對(duì)于每個(gè)JaveWeb應(yīng)用,在啟動(dòng)時(shí),Servlet容器都會(huì)創(chuàng)建一個(gè)ServletContext對(duì)象
12.在JSP中不能在不同用戶(hù)之間共享數(shù)據(jù)的方法是( )。
A) 通過(guò)cookie B) 利用文件系統(tǒng)
C) 利用數(shù)據(jù)庫(kù) D) 通過(guò)ServletContext對(duì)象
13.以下哪個(gè)不是Collection的子接口?( )。
A) List B) Set C) Map D) SortedSet
14. 下面正確的創(chuàng)建 Socket 的語(yǔ)句是( )。
A) Socket a = new Soeket(80):
B) Socket b = new Socket("130. 3. 4. 5", 80):
C) ServerSocket c = new Socket(80)
D) ServerSocket d = new Socket ("130. 3. 4, 5", 80)
15.下面的說(shuō)法正確的是( )。
A)帶有頁(yè)作用域的對(duì)象在一個(gè)web應(yīng)用程序的每個(gè)JSP中都存在.
B)指令指定與一個(gè)特定的JSP 請(qǐng)求不相關(guān)的全局信息。
C)當(dāng)JSP容器遇到開(kāi)始定制標(biāo)簽和結(jié)束定制標(biāo)簽時(shí),分別調(diào)用 doInitBody方法和doAfterBody方法。
D) 動(dòng)作只在翻譯時(shí)處理一次。
16.為了區(qū)分重載多態(tài)中同名的不同方法,要求:( )。
A)參數(shù)名不同 B) 采用不同的形式參數(shù)列表
C)返回值類(lèi)型不同 D) 選項(xiàng)A, B, C都對(duì)
17.下面是有關(guān)子類(lèi)調(diào)用父類(lèi)構(gòu)造函數(shù)的描述正確的是:( )。
A)子類(lèi)定義了自己的構(gòu)造函數(shù).就不會(huì)調(diào)用父類(lèi)的構(gòu)造函數(shù)
B)子類(lèi)必須通過(guò)Super關(guān)鍵字調(diào)用父類(lèi)有參數(shù)的構(gòu)造函數(shù)
C)如果子類(lèi)的構(gòu)造沒(méi)有通過(guò)super調(diào)用父類(lèi)構(gòu)造函數(shù),那么子類(lèi)會(huì) 先調(diào)用子類(lèi)自己的構(gòu)造函數(shù),再調(diào)用父類(lèi)不含參數(shù)的構(gòu)造函數(shù)。
D)創(chuàng)建子類(lèi)的對(duì)象時(shí),先調(diào)用子類(lèi)自己的構(gòu)造函數(shù),然后調(diào)用父 類(lèi)的構(gòu)造函數(shù)
18.在Java中,負(fù)責(zé)對(duì)字節(jié)代碼解釋執(zhí)行的是( )。
A) 垃圾回收器 B) 虛擬機(jī) C) 編譯器 D) 多線(xiàn)程機(jī)制
19.一個(gè)java程序運(yùn)行從上到下的環(huán)境次序是( )。
A) 操作系統(tǒng)、Java程序、jre/jvm、硬件
B) jre/jvm、Java程序、硬件、操作系統(tǒng)
C) java程序、jre/jvm、操作系統(tǒng)、硬件
D) java程序、操作系統(tǒng)、jre/jvm、硬件
20.對(duì)于從Employee表中選擇記錄的以下代碼片段,識(shí)別其遺漏的代碼行。( ) Connection con = null:
Class. forName("sun.jdbc.odbc.JdbcOdbcDriver"):
con=DriverManager.getConnection("jdbc:odbc:ss" , "sa" , "");
ResultSet rs=stat.executeQuery("select * from Employee");
A) Statement stat=createStatement();
B) Statement stat=con.createStatement ();
C) PreparedStatement stat=con.createStatement():
D) PreparedStatement stat=createPreparedStatement();
二、問(wèn)答題(本大題6小題,共40分)。
1.請(qǐng)說(shuō)出 ArrayList , Vector , LinkedList 的存儲(chǔ)性能和特性。(6分)
2.什么是單例模式(Singleton) ? 請(qǐng)?jiān)谙旅鎸?xiě)出一個(gè)單例模式類(lèi),并支持多線(xiàn)程調(diào)用。(6分)
3.請(qǐng)描述一下JVM加載class文件的原理機(jī)制?(6分)
4.請(qǐng)談?wù)剬?duì)SQL注入的理解,請(qǐng)給出你知道的防止SQL注入的方法。(6分)
5.請(qǐng)談?wù)剬?duì)hibernate的理解,并簡(jiǎn)要敘述Hibernate的一級(jí)緩存和二級(jí)緩存(8分)。
6.請(qǐng)寫(xiě)出你知道的排序方法,并使用Java語(yǔ)言寫(xiě)出其中一種。(8分)
三、簡(jiǎn)答題(參考答案)
1. ArrayList和Vector都是使用數(shù)組方式存儲(chǔ)數(shù)據(jù),此數(shù)組元素?cái)?shù)大于實(shí)際存儲(chǔ)的數(shù)據(jù)以便增加和插入元素,它們都允許直接按序號(hào)索引元素,但是插入元素要涉及數(shù)組元素移動(dòng)等內(nèi)存操作,所以索引數(shù)據(jù)快而插入數(shù)據(jù)慢,Vector由于使用了synchronized方法(線(xiàn)程安全),通常性能上較ArrayList差,而LinkedList使用雙向鏈表實(shí)現(xiàn)存儲(chǔ),按序號(hào)索引數(shù)據(jù)需要進(jìn)行前向或后向遍歷,但是插入數(shù)據(jù)時(shí)只需要記錄本項(xiàng)的前后項(xiàng)即可,所以插入速度較快。
2. 創(chuàng)建某類(lèi)對(duì)象時(shí),無(wú)論創(chuàng)建多少次該類(lèi)對(duì)象只有一份在內(nèi)存中,這就是單例模式。支持多線(xiàn)程調(diào)用,考慮線(xiàn)程安全,只需要加鎖即可。
public class Singleton{
private static Singleton instance = null;
private Singleton(){}
private static synchronized void syncInit(){
if(instance == null){
instance = new Singleton();
}
}
public static Singleton getInstance(){
if(instance == null){
syncInit();
}
return instance;
}
}
3. JVM中類(lèi)的裝載是由ClassLoader和它的子類(lèi)來(lái)實(shí)現(xiàn)的,Java ClassLoader是一個(gè)重要的Java運(yùn)行時(shí)系統(tǒng)組件。它負(fù)責(zé)在運(yùn)行時(shí)查找和裝入類(lèi)文件的類(lèi)。
4.解決辦法:a. 利用JavaScript,在客戶(hù)端進(jìn)行校驗(yàn)。
b.程序判斷 c.使用PreparedStatement連接數(shù)據(jù)庫(kù)。(參數(shù)化) d.利用框架技術(shù)
5. Hibernate是一個(gè)開(kāi)放源代碼的對(duì)象關(guān)系映射框架,它對(duì)JDBC進(jìn)行了非常輕量級(jí)的對(duì)象封裝,使得Java程序員可以隨心所欲的使用對(duì)象編程思維來(lái)操縱數(shù)據(jù)庫(kù)。 Hibernate可以應(yīng)用在任何使用JDBC的場(chǎng)合,既可以在Java的客戶(hù)端程序使用,也可以在Servlet/JSP的Web應(yīng)用中使用。
一級(jí)緩存就是Session級(jí)別的緩存,一個(gè)Session做了一個(gè)查詢(xún)操作,它會(huì)把這個(gè)操作的結(jié)果放在一級(jí)緩存中,如果短時(shí)間內(nèi)這個(gè)
session(一定要同一個(gè)session)又做了同一個(gè)操作,那么hibernate直接從一級(jí)緩存中拿,而不會(huì)再去連數(shù)據(jù)庫(kù),取數(shù)據(jù);
二級(jí)緩存就是SessionFactory級(jí)別的緩存,顧名思義,就是查詢(xún)的時(shí)候會(huì)把查詢(xún)結(jié)果緩存到二級(jí)緩存中,如果同一個(gè)sessionFactory
創(chuàng)建的某個(gè)session執(zhí)行了相同的操作,hibernate就會(huì)從二級(jí)緩存中拿結(jié)果,而不會(huì)再去連接數(shù)據(jù)庫(kù);
6.插入排序、希爾排序、冒泡排序、快速排序、直接排序、歸并排序 下面以快速排序?yàn)槔?/p>
1. public class quickSort {
2.
3. inta[]={49,38,65,97,76,13,27,49,78,34,12,64,5,4,62,99,98,54,56,17,18,23,34
,15,35,25,53,51};
4. public quickSort(){
5. quick(a);
6. for(int i=0;i
7. System.out.println(a[i]);
8. }
9. }
10. public int getMiddle(int[] list, int low, int high) {
11. int tmp =list[low]; //數(shù)組的第一個(gè)作為中軸
12. while (low < high){
13. while (low < high&& list[high] >= tmp) {
14. high--;
15. }
16.
17. list[low] =list[high]; //比中軸小的記錄移到低端
18. while (low < high&& list[low] <= tmp) {
19. low++;
20. }
21.
22. list[high] =list[low]; //比中軸大的記錄移到高端
23. }
24. list[low] = tmp; //中軸記錄到尾
25. return low; //返回中軸的位置
26. }
27.
28. public void _quickSort(int[] list, int low, int high) {
29. if (low < high){
30. int middle =getMiddle(list, low, high); //將list 數(shù)組進(jìn)行一分為二
31. _quickSort(list, low, middle - 1); //對(duì)低字表進(jìn)行遞歸排序
32. _quickSort(list,middle + 1, high); //對(duì)高字表進(jìn)行遞歸排序
33. }
34. }
35.
36. public void quick(int[] a2) {
37. if (a2.length > 0) { //查看數(shù)組是否為空
38. _quickSort(a2,0, a2.length - 1);
39. }
40. }
41. }