中级JAVA笔试题(附参考题答案) 下载本文

. . . .

中级JAVA笔试题(附参考答案)

java 基础

1. StringBuffer的实现方式,容量如何扩充。 2. ClassLoader的功能和工作模式。 3. ==和equals的区别 。

4. 什么是线程安全?举例说明一个线程不安全的例子。 5. 说出数据连接池的工作机制,解决什么问题。

6. 一个字符串\,把其中奇

数位java(大小写不敏感)替换成java,偶数位替换成JAVA。 数据库

7. 经常使用的数据库的优化方法。

8. 薪水最高的第10到第20名雇员Oracle和mysql的实现。

算法:

9. ArrayList LinkedList HashMap,存储性能和特点。 10. 用任意方法对int类型数组进行排序。

架构:

11. 描述MVC的设计思想 12. Spring的核心理念是什么 13. 谈一下自己最熟悉的web框架

可编辑

. . . .

参考答案: java 基础

1. StringBuffer的实现方式,容量如何扩充。(StringBuffer是通过char[]来实现的,默

认长度是16,在进行串的append的时,StringBuffer会检测剩余容量,适时会重新扩充,而扩容的同时,会创建一个新的数组,并将原来的数组内容复制到新的数组里面。)

2. ClassLoader的功能和工作模式。(1:JVM在运行时会产生三个ClassLoader,其层次关

系::Bootstrap ClassLoader—>Extension ClassLoader—>AppClassLoader,2: 当一个装载器被请求装载某个类时,它首先委托自己的parent去装载,若parent能装载,则返回这个类所对应的Class对象,若parent不能装载,则由parent的请求者去装载。)

3. ==(引用指向同一个对象)和equals(引用可能指向的不是同一个对象)的区别 。 4. 什么是线程安全(在函数执行过程中不会造成资源冲突),举例说明一个线程不安全

的例子。

5. 说出数据连接池的工作机制,(服务器启动时会建立一定数量的池连接,并一直维持不少

于此数目的池连接。客户端程序需要连接时,池驱动程序会返回一个未使用的池连接并将其表记为忙。如果当前没有空闲连接,池驱动程序就新建一定数量的连接,新建连接的数量有配置参数决定。当使用的池连接调用完成后,池驱动程序将此连接表记为空闲,其他调用就可以使用这个连接。)

解决什么问题(性能)。

6. 一个字符串\,把其中奇

数位上的java(大小写不敏感)替换成java,偶数位替换成JAVA。

import java.util.regex.Matcher; import java.util.regex.Pattern;

public class Test {

afasdfasdf\

StringBuffer buf = new StringBuffer(); int i=0; while(m.find()) {

public static void main(String[] args) {

Pattern p = Pattern.compile(\

Matcher m = p.matcher(\Java JAVa JaVa IloveJAVA you hateJava

可编辑

. . . .

}

}

m.appendTail(buf); p(buf); }

i++;

if(i%2 == 0) { }

m.appendReplacement(buf, \m.appendReplacement(buf, \} else {

数据库

7. 经常使用的数据库的优化方法。(索引,缓存,sql优化,分表等) 8. 薪水最高的第10到第20名雇员Oracle和mysql的实现。

Oracle:

select ename, sal

from (select ename, sal, rownum r

from (select ename, sal from emp order by sal desc) ) where r >= 10 and r <= 20

mysql:select ename, sal from emp order by sal desc LIMIT 10,10

算法:

9. ArrayList(查询性能高,插入删除性能低) LinkedList(查询性能低,插入删除性能高)

HashMap(性能介于两者之间),存储性能和特点。

10. 用任意方法对int类型数组进行排序。(Collections.Sort(ArrayList))

(public class NumSort {

可编辑

public static void main(String[] args) {

int[] a = new int[args.length]; for (int i=0; i

a[i] = Integer.parseInt(args[i]);