论坛首页 Java企业应用论坛

今天到笔试,把笔试题大家一起分享下(题目蛮有代表性)

浏览 3505 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2009-08-13   最后修改:2009-08-13
今天去面试碰到的面试题目,感觉做的不是很好,自己没有啥实际开发经验所以要实例的不会写,请大家把自己的答案亮出来分享下:
1. 什么是装饰模型?举个例子在Java API ,J2EE种的具体应用。

装饰着模式(Decorator): 动态的给一个对象添加一些额外的职责.
比如java.io包. BufferedInputStream封装了FileInputStream, 它们都实现了InputStream接口, 但前者实现了readLine方法.

2. 方法重载和覆盖的区别?在它们当中运用Execption有什么区别?
重载:在同一个类中,具有相同的方法名(不同参数类型、个数,返回类型)
覆盖:父类与子类之间,拥有完全一样的参数,返回类型
重载的Exception是同一范围的,覆盖子类的Exception小于或等于父类的
(个人认为的,表达可能不准确,若不对请指正)

3. 事务的隔离性分为哪几级?对系统有什么影响? SPRING是如何控制事务的?
1. 可重复读2s.读稳定性3.游标稳定性4.未提交读
当事务没有设置隔离级别将会产生以下三种情况:
1) 脏读,一个事务读取未提交的的数据时。
事务1修改了某数据而未提交,事务2去读取该数据。当事务1回滚了,则事务2读取了未存在的数据
2) 重复读取,2次读取得到不同数据。事务1读取一行数据,事务2修改了或者删除了,事务再去读取会得到不一样的数据,或者不存在数据了。
3) 幻影数据,发生在一行数据满足搜索规则,却在刚开始没被看到。事务1读取了一些列满足搜索的行,事务2插入一条满足事务1搜索规则的行。事务1再次进行查询语句会得到不同一些列的行。
Spring管理事务不依赖J2EE服务器,在Spring种把任何函数纳入spring的事务管理,通过在applicationContext.xml文件中配置。Spring容器管理事务是自动回滚的,也就是被纳入事务管理的类的函数执行完毕,自动被提交。

4. 创建主键的几种方式?
主键一般是在创建表时候定义的:
create table a(id int primary key auto_increment,name varchar(20))
或通过修改表的方式加入主键:
“ALTER TABLE tablename ADD PRIMARY KEY (列的列表); ”。每个表只能有一个主键。

5. 有一个表A写出ID重复次数大于3的所有记录(SQL语句)?

6. 谈谈JVM1.5垃圾回收机制?System.gc()的作用?
7. 什么是线程安全性?Servlet是线程安全的吗?如果是,它是如何做的?不是,我们该怎么做?EJB是线程安全的不?如果是,它是怎样做的?不是,我们该怎么做?

8. 写出XML的几种解析方式?它们各自的缺点?
DOM,SAX,STAX,
DOM处理大文件时候性能下降非常大。由于DOM得树结构造成的,这个结构占内存较多而且DOM解析文件之前必须,必须把整个文件装入内存当中。
SAX
1) 不直观,程序员很容易在概念上处理不当(想什么数据就直接去取,而不是SAX这种数据依次被抛出,再由程序员处理)
2) 数据收集同时也彻底的把XML结构过滤了一遍,数据流动性是有顺序的如果你不在自已的代码中考虑到数据流将会出现的顺序,在进行SAX解析过程中进行定位的代码就会发散失控并产生很多复杂的相互耦合(或称牵制)。
(不太理解是什么意思)

9. 什么是读写锁?用JAVA写出它的一个实例?
 读写锁实际是一种特殊的自旋锁,它把对共享资源的访问者划分成读者和写者,读者只对共享资源进行读访问,写者则需要对共享资源进行写操作。这种锁相对于自旋锁而言,能提高并发性,因为在多处理器系统中,它允许同时有多个读者来访问共享资源,最大可能的读者数为实际的逻辑CPU数。写者是排他性的,一个读写锁同时只能有一个写者或多个读者(与CPU数相关),但不能同时既有读者又有写者。
 在读写锁保持期间也是抢占失效的。
如果读写锁当前没有读者,也没有写者,那么写者可以立刻获得读写锁,否则它必须自旋在那里,直到没有任何写者或读者。如果读写锁没有写者,那么读者可以立即获得该读写锁,否则读者必须自旋在那里,直到写者释放该读写锁。
JAVA写出它的一个实例(这个不会写,高手指导)

10. 解释下数据库的索引?什么时候要用索引?索引的影响?
使用索引可快速访问数据库表中的特定信息。索引是对数据库表中一列或多列的值进行排序的一种结构,例如 employee 表的姓(lname)列。如果要按姓查找特定职员,与必须搜索表中的所有行相比,索引会帮助您更快地获得该信息。
索引提供指向存储在表的指定列中的数据值的指针,然后根据您指定的排序顺序对这些指针排序。数据库使用索引的方式与您使用书籍中的索引的方式很相似:它搜索索引以找到特定值,然后顺指针找到包含该值的行。

   发表时间:2009-08-13  
zhouwenkui 写道

2. 方法重载和覆盖的区别?在它们当中运用Execption有什么区别?
重载:在同一个类中,具有相同的方法名(不同参数类型、个数,返回类型)

返回类型不能构成重载的
0 请登录后投票
   发表时间:2009-08-13  
另外,重载的exception应该是互相没有关系的
0 请登录后投票
   发表时间:2009-08-13  
elmar 写道
zhouwenkui 写道

2. 方法重载和覆盖的区别?在它们当中运用Execption有什么区别?
重载:在同一个类中,具有相同的方法名(不同参数类型、个数,返回类型)

返回类型不能构成重载的

恩 查了下你是对的 以前没好好的理解

方法重载:一.方法名一定要相同。二.方法的参数表必须不同,包括参数的类型或个数,以此区分不同的方法体。
  1.如果参数个数不同,就不管它的参数类型了!
  2.如果参数个数相同,那么参数的类型或者参数的顺序必须不同。
  三.方法的返回类型、修饰符可以相同,也可不同。
0 请登录后投票
   发表时间:2009-08-13  
5. 有一个表A写出ID重复次数大于3的所有记录(SQL语句)?

select * from A group by ID having count(ID)>3

如果A表还有其他字段 但其他字段有不同如name字段
select distinct name,ID from A where ID in(select ID from A group by ID having count(ID)>3)
0 请登录后投票
论坛首页 Java企业应用版

跳转论坛:
Global site tag (gtag.js) - Google Analytics